如何创建仅运行已更改的测试文件的Guard配置监视?

时间:2013-02-27 22:59:42

标签: guard

关于如何在线执行此操作的信息不多,但在我的Guardfile中,我正在设置watch以查找我希望Guard看到更改的各种目录/文件。如何为已更新的已更改spec/test文件指定监视,并仅在发生时运行该特定文件?谢谢!

guard 'rspec' do
  watch(%r|^spec/.+_spec\.rb$|)               { "spec" }
end

目前,当在spec目录下更改文件时,上面运行所有规范/测试。但我只希望运行更改的测试文件的测试。

当前spec目录树:

spec
 -models
  -user_spec.rb
  -classroom_spec.rb
 -controllers
  -classroom_spec.rb
 -lib
  -support_spec.rb

谢谢!

1 个答案:

答案 0 :(得分:3)

Guard RSpec插件有一个可以用

创建的演示Guardfile
$ bundle exec guard init rspec

,内容如下:

# A sample Guardfile
# More info at https://github.com/guard/guard#readme

guard 'rspec' do
  watch(%r{^spec/.+_spec\.rb$})
  watch(%r{^lib/(.+)\.rb$})     { |m| "spec/lib/#{m[1]}_spec.rb" }
  watch('spec/spec_helper.rb')  { "spec" }

  # Rails example
  watch(%r{^app/(.+)\.rb$})                           { |m| "spec/#{m[1]}_spec.rb" }
  watch(%r{^app/(.*)(\.erb|\.haml)$})                 { |m| "spec/#{m[1]}#{m[2]}_spec.rb" }
  watch(%r{^app/controllers/(.+)_(controller)\.rb$})  { |m| ["spec/routing/#{m[1]}_routing_spec.rb", "spec/#{m[2]}s/#{m[1]}_#{m[2]}_spec.rb", "spec/acceptance/#{m[1]}_spec.rb"] }
  watch(%r{^spec/support/(.+)\.rb$})                  { "spec" }
  watch('config/routes.rb')                           { "spec/routing" }
  watch('app/controllers/application_controller.rb')  { "spec/controllers" }

  # Capybara features specs
  watch(%r{^app/views/(.+)/.*\.(erb|haml)$})          { |m| "spec/features/#{m[1]}_spec.rb" }

  # Turnip features and steps
  watch(%r{^spec/acceptance/(.+)\.feature$})
  watch(%r{^spec/acceptance/steps/(.+)_steps\.rb$})   { |m| Dir[File.join("**/#{m[1]}.feature")][0] || 'spec/acceptance' }
end

我建议坚持这一点,因为它包含许多文件/文件夹命名和触发相关规范的最佳实践。

要回答您的问题,如果您省略监视表达式的块,Guard会使用具有更改的确切文件:

guard 'rspec' do
  watch(%r|^spec/.+_spec\.rb$|)
end

这会触发spec文件夹中以_spec.rb结尾的每个修改过的文件的RSpec插件。

监视表达式的块是将文件名转换为其他内容而黑色的参数是正则表达式的匹配,因此您可以为其添加一些特殊逻辑。简短的例子证明了这一点:

watch(%r{^lib/(.+)\.rb$})     { |m| "spec/lib/#{m[1]}_spec.rb" }

lib/file.rb中的文件更改将触发插件,并且块会将该文件名转换为spec/lib/file_spec.rb,因为m[1]包含RegExp中的匹配组,即{{1} }。

相关问题