Rails 3.1: тестирование "DELETE 'destroy'" в спецификациях контроллера и маршрута

Я тестирую приложение, которое использует Sorcery для аутентификации. У меня есть контроллер сессий, который обрабатывает вход / выход пользователя с тестами, чтобы выполнить действия. Я понимаю, что действие уничтожения обычно принимает идентификатор в качестве параметра, но это не нужно с функцией выхода.

routes.rb

resources :sessions

# match "/signout", :to => "sessions#destroy"

sessions_controller_spec.rb

describe "DELETE 'destroy'" do
  it "should log the user out" do
    login_user(Factory(:user))
    delete :destroy
    controller.current_user.should be_nil
    controller.should_not be_signed_in
  end 
end

session_routes_spec.rb

it "should route DELETE /sessions to sessions#destroy" do
  { :delete => "/sessions" }.should route_to(
    :controller => "sessions",
    :action => "destroy"
  )
end

Оба вышеуказанных теста не пройдены, поскольку маршрут ожидает идентификатор. Есть ли способ избавиться от этой необходимости? Я знаю, что мог бы просто использовать названный маршрут "signout_path", но мне просто любопытно, могу ли я все еще использовать session_path,:method =>:delete, не передавая ему идентификатор.

Что меня действительно шокирует, так это если я раскомментирую совпадение "/signout", которое проходит спецификация контроллера (однако, спецификация маршрута - нет). Как строка соответствия вызывает прохождение спецификации контроллера?

1 ответ

Попробуйте отобразить действие уничтожения как: метод сбора ресурсов сессий, в вашем config/rout.rb:

resources :sessions, :collection => [:destroy]

По умолчанию destroy - это метод "member", для работы которого требуется указанный ресурс.

Другие вопросы по тегам