Учебник Guard Ruby On Rails 3.2

Я следую руководству по Ruby on Rails.

Все работает довольно хорошо, но я заметил, что 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    

У меня нет папки spec/routing.

Кто-нибудь видел простую опечатку? Или есть какие-то другие соображения, которые мне нужно иметь?

Я на рельсах 3.2

Спасибо


person Tyler DeWitt    schedule 01.02.2012    source источник
comment
Если у вас нет каталога spec/routing, зачем вы его смотрите? :-)   -  person Sergio Tulentsev    schedule 02.02.2012
comment
Я просто следил за учебником   -  person Tyler DeWitt    schedule 02.02.2012


Ответы (2)


Нашел это:

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

Обратите внимание на второй } между routing и spec

Теперь читает:

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

Также объясняет отсутствующие каталоги shananigans.

Спасибо!

person Tyler DeWitt    schedule 01.02.2012

Не могу прокомментировать ваш ответ, Тайлер (может быть, потому что я здесь новичок), но я думаю, что вы повторили несколько строк в Guardfile:

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

Я заметил, что это дважды запускает тесты; удаление повторяющихся строк решило это.

person Sajeev Shanmuganandarajah    schedule 07.09.2012