1

私はRubyonRailsチュートリアルをフォローしています。

物事はかなりうまく機能していますが、Guardはいくつかのファイル(ビューまたはコントローラーファイル)を保存した後にのみ実行され、他のファイル(ルートまたはスペックファイル)を保存したときには実行されないことに気付きました。GuardをSporkに接続しましたが、それが重要かどうかはわかりません。

Guard / Sporkを実行しているコンソールウィンドウを見ると、実行されていないテストを保存した後にエラーが発生しました。

Exception encountered: #<LoadError: no such file to load -- /Users/Tyler/Development/FirstRails/sample_app/spec/routing

Guardファイルの構文がわからないので、例をコピーしました。Guardファイルは次のとおりです。

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

guard 'rspec', :version => 2, :all_after_pass=>false, :cli => '--drb' do
  watch(%r{^spec/.+_spec\.rb$})
  watch(%r{^lib/(.+)\.rb$})     { |m| "spec/lib/#{m[1]}_spec.rb" }
  watch('spec/spec_helper.rb')  { "spec" }

  # my edits
  watch(%r{^app/controllers/(.+)_(controller)\.rb$}) do |m|
   ["spec/routing/#{m[1]}_routing}spec.rb",
   "spec/#{m[2]}s/#{m[1]}_${m[2]}_spec.rb",
   "spec/acceptance/#{m[1]}_spec.rb",
   "spec/requests/#{m[1]}_spec.rb"]
 end

  # Rails example
  watch(%r{^spec/.+_spec\.rb$})
  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{^lib/(.+)\.rb$})                           { |m| "spec/lib/#{m[1]}_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('spec/spec_helper.rb')                        { "spec" }
  watch('config/routes.rb')                           { "spec/routing" }
  watch('app/controllers/application_controller.rb')  { "spec/controllers" }
  # Capybara request specs
  watch(%r{^app/views/(.+)/.*\.(erb|haml)$})          { |m| "spec/requests/#{m[1]}_spec.rb" }
end

guard 'spork', :cucumber_env => { 'RAILS_ENV' => 'test' }, :rspec_env => { 'RAILS_ENV' => 'test' } do
  watch('config/application.rb')
  watch('config/environment.rb')
  watch(%r{^config/environments/.+\.rb$})
  watch(%r{^config/initializers/.+\.rb$})
  watch('Gemfile')
  watch('Gemfile.lock')
  watch('spec/spec_helper.rb')
  watch('test/test_helper.rb')
end

特に、私の編集:

  # my edits
  watch(%r{^app/controllers/(.+)_(controller)\.rb$}) do |m|
   ["spec/routing/#{m[1]}_routing}spec.rb",
   "spec/#{m[2]}s/#{m[1]}_${m[2]}_spec.rb",
   "spec/acceptance/#{m[1]}_spec.rb",
   "spec/requests/#{m[1]}_spec.rb"]
 end    

スペック/ルーティングフォルダがありません。

誰かが単純なタイプミスを見ますか?または、他に考慮すべき点はありますか?

私はレール3.2にいます

ありがとう

4

2 に答える 2

2

それを見つけた:

 ["spec/routing/#{m[1]}_routing}spec.rb",

との}間の2番目に注意してくださいroutingspec

今読みます:

 ["spec/routing/#{m[1]}_routing_spec.rb",

また、欠落しているディレクトリのシャナニガンについても説明します。

ありがとう!

于 2012-02-01T20:18:19.860 に答える
1

タイラーの答えにコメントすることはできませんが(おそらく私はここで新しいためです)、Guardfileで数行繰り返したと思います。

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

これがテストを2回実行していることに気づきました。重複する行を削除すると、これが解決しました。

于 2012-09-07T12:27:18.447 に答える