Rails:删除capybara,bug或我的错误请求?

时间:2013-05-08 14:53:00

标签: ruby-on-rails ruby capybara railstutorial.org

Michael Hartl's Rails Tutorial (Rails 3.2)中,如代码清单9.52所示:

      describe "when signing in again" do
        before do
          delete signout_path
          print page.html <---- Insert this here
          visit signin_path
          print page.html <---- Insert here again
          fill_in "Email",    with: user.email
          fill_in "Password", with: user.password
          click_button "Sign in"
        end

        it "should render the default (profile) page" do
          page.should have_selector('title', text: user.name) 
        end
      end

我插入了这两张照片。而且,令人惊讶的是我得到了同一页面的打印输出(不应该是,它应该在发送DELETE请求后将您带回根URL)。发生这种情况后,由于visit signin_path将我带回登录页面,登录程序会成功,测试用例也会成功。但是,第二个print page.html向我提供了仍然登录的用户的标题。

当我将delete signout_path更改为click_link "Sign out"时,它有效。

我的代码中是否遗漏了某些内容,或者它是Capybara的错误? (因为我很确定我跟着一切正确......)

更新 如果我将delete signout_path更改为Capybara.current_session.driver.delete signout_path,它也可以正常工作。 (意思是水豚用户正确签名)

更新

这些是文件(会话控制器和助手):

sessions_controller.rb

class SessionsController < ApplicationController

  def new
  end

  def create
    user = User.find_by_email(params[:session][:email].downcase)
    if user && user.authenticate(params[:session][:password])
      sign_in user
      redirect_back_or user
    else
      flash.now[:error] = 'Invalid email/password combination'
      render 'new'
    end
  end

  def destroy
    sign_out
    redirect_to root_url
  end

end

sessions_helper.rb

module SessionsHelper
  def sign_in(user)
    cookies.permanent[:remember_token] = user.remember_token
    self.current_user = user
  end

  def signed_in?
    !current_user.nil?
  end

  def current_user=(user)
    @current_user = user
  end

  def current_user?(user)
    user == current_user
  end

  def signed_in_user
    unless signed_in?
      store_location
      redirect_to signin_url, notice: "Please sign in."
    end
  end

  def current_user
    @current_user ||= User.find_by_remember_token(cookies[:remember_token])
  end

  def sign_out
    self.current_user = nil
    cookies.delete(:remember_token)
  end

  def redirect_back_or(default)
    redirect_to(session[:return_to] || default)
    session.delete(:return_to)
  end

  def store_location
    session[:return_to] = request.url
  end
end

的routes.rb

DemoApp::Application.routes.draw do
  ...

  root to: 'static_pages#home'

  match '/signup', to: 'users#new'
  match '/signin', to: 'sessions#new'
  match '/signout', to: 'sessions#destroy', via: :delete

  resources :sessions, only: [:new, :create, :destroy]

  ...

end

2 个答案:

答案 0 :(得分:3)

delete signout_path不适用于Capybara功能规格。 getpostputdelete是特定于控制器规范的方法,在功能规范中不可用。

您还希望在Capybara规范中提出实际请求(通过点击,提交等等),因为这通常是您要测试的内容。

如果您想确保会话清晰为“设置”,最好通过模型进行。

顺便说一句,如果您在“再次登录时”查看您所描述的内容时,您可能希望实际“退出”以便实际“再次登录”。

答案 1 :(得分:2)

您可以尝试以下操作:

page.driver.submit :delete, '/users/sign_out', {}