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
我建议坚持这一点,因为它包含许多文件/文件夹命名和触发相关规范的最佳实践。
要回答您的问题,如果您省略 watch 表达式的块,Guard 会使用发生更改的确切文件:
guard 'rspec' do
watch(%r|^spec/.+_spec\.rb$|)
end
这将为 spec 文件夹中以_spec.rb
.
监视表达式的块用于将文件名转换为其他内容,黑色的参数是正则表达式的匹配,因此您可以为其添加一些特殊逻辑。演示这一点的简短示例:
watch(%r{^lib/(.+)\.rb$}) { |m| "spec/lib/#{m[1]}_spec.rb" }
文件更改lib/file.rb
将触发插件,并且该块将该文件名转换为spec/lib/file_spec.rb
,因为m[1]
包含来自 RegExp 的匹配组,即file
.