Rspec安装错误-参数无效

use*_*363 2 rspec ruby-on-rails

我刚移动到在Win 10 / ruby​​ 2.2.2 / Rails 4.2.0上运行的新笔记本电脑(在以前的Win 8 ruby​​ 2.0.0 / Rails 4.2 / rspec 3.2上没有问题)。现在安装时rspec,下面有一个奇怪的错误:

$ rails g rspec:install
   identical  .rspec
       exist  spec
      create  spec/C:/Users/Jun C/AppData/Local/Temp/d20160219-10996-1x6hu8w/spec/spec_helper.rb
C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:252:in `mkdir': Invalid argument @ dir_s_mkdir - C:/D/code/rails_proj/engines/simple_orderx/spec/C: (Errno::EINVAL)
        from C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:252:in `fu_mkdir'
        from C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:226:in `block (2 levels) in mkdir_p'
        from C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:224:in `reverse_each'
        from C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:224:in `block in mkdir_p'
        from C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:210:in `each'
        from C:/Ruby22-x64/lib/ruby/2.2.0/fileutils.rb:210:in `mkdir_p'
        from C:/Ruby22-x64/lib/ruby/gems/2.2.0/gems/thor-0.19.1/lib/thor/actions/create_file.rb:61:in `block in invoke!'
        from C:/Ruby22-x64/lib/ruby/gems/2.2.0/gems/thor-0.19.1/lib/thor/actions/empty_directory.rb:116:in `call'
        from C:/Ruby22-x64/lib/ruby/gems/2.2.0/gems/thor-0.19.1/lib/thor/actions/empty_directory.rb:116:in `invoke_with_conflict_check'
        from C:/Ruby22-x64/lib/ruby/gems/2.2.0/gems/thor-0.19.1/lib/thor/actions/create_file.rb:60:in `invoke!'
Run Code Online (Sandbox Code Playgroud)

/spec在Rails应用程序的根。该spec-helper文件应该下产生/spec/spec/spec-helper.rb。但是安装试图产生spec-helperspec/C:/Users/Jun C/AppData/Local/Temp/d20160219-10996-1x6hu8w/spec/。似乎路径是错误的。

这是中的行Gemfile

s.add_development_dependency "rspec-rails", ">= 3.2.0"
Run Code Online (Sandbox Code Playgroud)

这是配置 engine.rb

   config.generators do |g|
      g.template_engine :erb
      g.integration_tool :rspec
      g.test_framework :rspec
      g.fixture_replacement :factory_girl, :dir => "spec/factories"  
    end  
Run Code Online (Sandbox Code Playgroud)

rspec版本是3.2.2。如何在rspec安装中解决此错误路径?

Ben*_*mos 5

我的环境

  • Windows 10
  • 红宝石2.4.4p296(2018-03-28修订版63013)[x64-mingw32]
  • Rails 5.2.0
  • rspec-rails(3.7.2)
  • 雷神(0.20.0)

TL; DR

因为Dir.mktmpdir(由RSpec-rails使用)和Dir.glob(由Thor使用)在Windows 10上返回不匹配的用户目录路径,所以Thor无法正确生成相对路径,从而导致无效路径,从而导致文件操作失败。此问题是Windows 10特有的。请确保您的RSpec-rails和Thor宝石是最新的。如果这样不能解决您的问题,请参见下面的解决方法。

引擎盖下

rails generate rspec:install命令:

  1. 创建一个临时目录
  2. 用它需要的文件填充它
  3. 使用Thor将这些文件复制到Rails应用中

RSpec-rails Dir.mktmpdir在第一步中使用。在Windows 10上,结果路径如下所示:

Dir.mktmpdir() => C:/Users/BEN~1.AMO/AppData/Local/Temp/...
Run Code Online (Sandbox Code Playgroud)

此路径派生自Windows 10 TMP环境变量:

irb(main):005:0> ENV['TMP']
=> "C:\\Users\\BEN~1.AMO\\AppData\\Local\\Temp"
Run Code Online (Sandbox Code Playgroud)

Thor Dir.glob在第三步中寻找要复制的文件时使用。在Windows 10上,找到的路径如下所示:

Dir.glob(lookup, File::FNM_DOTMATCH) => C:/Users/ben.amos/AppData/Local/Temp/...
Run Code Online (Sandbox Code Playgroud)

这些路径是从HOME环境变量派生的:

irb(main):006:0> ENV['HOME']
=> "C:/Users/ben.amos"
Run Code Online (Sandbox Code Playgroud)

当Thor找到要复制的文件时Dir.glob,它首先尝试通过删除路径的temp目录部分来导出相对路径,该目录是由创建的Dir.mktmpdir。但是,由于Dir.globDir.mktmpdir路径不匹配,String.gsub什么也不做,因此保留了绝对路径,随后的文件路径操作创建了无效的路径字符串,并且... BOOM。如OP所述,复制失败。

如果好奇,您可以通过查看以下两个文件来自己验证此行为:

RSpec-rails gem: lib\generators\rspec\install\install_generator.rb
Thor gem: lib\thor\actions\directory.rb
Run Code Online (Sandbox Code Playgroud)

解决方法

我能够产生的最简单,侵入性最小的解决方法是暂时设置ENV['TMP']其他功能。您可以在Rails设置过程的早期进行此操作。只需使用一些非用户特定的路径,如下所示:

  1. 打开config/application.rb
  2. 将以下内容添加到Application类的底部。

    ENV['TMP'] = 'C:/Windows/Temp' # or any other valid temp directory

  3. 运行rails generate rspec:install

  4. 删除在步骤2中添加的行。

所需文件放置到位后,您不必再为此担心。

正式修复

RSpec可能需要Windows伙计使用不同的临时目录,或者Thor需要为其路径使用更智能的逻辑。雷神(Thor)的Github上一张公开票