가드 RSpec에 플러그인은
$ bundle exec guard init rspec
로 만들 수 있습니다 데모 Guardfile을 가지고 있으며, 내용은 다음과 같다 :이 가장 많이 포함되어 있기 때문에
# 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 'rspec' do
watch(%r|^spec/.+_spec\.rb$|)
end
사양 폴더에 수정 된 각 파일에 대한 RSpec에 플러그인을 실행할 것입니다 :
는 시계 식의 블록을 생략하면, 가드의 변화가 있었다 정확한 파일을 사용하여, 귀하의 질문에 대답하려면 이는
_spec.rb
으로 끝납니다.
시계 표현식의 블록은 파일 이름을 다른 것으로 변환하고 검정색 매개 변수는 정규 표현식과 일치하므로 일부 특수 논리를 추가 할 수 있습니다. 이 문제를 보여주는 짧은 예 :
watch(%r{^lib/(.+)\.rb$}) { |m| "spec/lib/#{m[1]}_spec.rb" }
lib/file.rb
에있는 파일 변경은 플러그인을 트리거하고 m[1]
이 file
인 정규식에서 일치 그룹을 포함하기 때문에 블록은 spec/lib/file_spec.rb
해당 파일 이름을 변환합니다.