在请求规范中存根身份验证 [英] Stubbing authentication in request spec
问题描述
在编写请求规范时,如何设置会话和/或存根控制器方法? 我正在尝试在集成测试中保留身份验证-rspec/requests
When writing a request spec, how do you set sessions and/or stub controller methods? I'm trying to stub out authentication in my integration tests - rspec/requests
这是一个测试示例
require File.dirname(__FILE__) + '/../spec_helper'
require File.dirname(__FILE__) + '/authentication_helpers'
describe "Messages" do
include AuthenticationHelpers
describe "GET admin/messages" do
before(:each) do
@current_user = Factory :super_admin
login(@current_user)
end
it "displays received messages" do
sender = Factory :jonas
direct_message = Message.new(:sender_id => sender.id, :subject => "Message system.", :content => "content", :receiver_ids => [@current_user.id])
direct_message.save
get admin_messages_path
response.body.should include(direct_message.subject)
end
end
end
助手:
module AuthenticationHelpers
def login(user)
session[:user_id] = user.id # session is nil
#controller.stub!(:current_user).and_return(user) # controller is nil
end
end
以及处理身份验证的ApplicationController:
And the ApplicationController that handles authentication:
class ApplicationController < ActionController::Base
protect_from_forgery
helper_method :current_user
helper_method :logged_in?
protected
def current_user
@current_user ||= User.find(session[:user_id]) if session[:user_id]
end
def logged_in?
!current_user.nil?
end
end
为什么无法访问这些资源?
Why is it not possible to access these resources?
1) Messages GET admin/messages displays received messages
Failure/Error: login(@current_user)
NoMethodError:
undefined method `session' for nil:NilClass
# ./spec/requests/authentication_helpers.rb:3:in `login'
# ./spec/requests/message_spec.rb:15:in `block (3 levels) in <top (required)>'
推荐答案
请求规范是 ActionDispatch::IntegrationTest
,它不能像控制器规范那样工作(包装 ActionController::TestCase
).即使有可用的会话方法,我也不支持它(即可能存在,因为为其他实用程序包含的模块也包含该方法).
A request spec is a thin wrapper around ActionDispatch::IntegrationTest
, which doesn't work like controller specs (which wrap ActionController::TestCase
). Even though there is a session method available, I don't think it is supported (i.e. it's probably there because a module that gets included for other utilities also includes that method).
我建议通过发布到用于验证用户身份的任何操作来登录.如果您为所有User工厂设置密码"password"(例如),则可以执行以下操作:
I'd recommend logging in by posting to whatever action you use to authenticate users. If you make the password 'password' (for example) for all the User factories, then you can do something like this:
def login(user)
post login_path, :login => user.login, :password => 'password'
end
这篇关于在请求规范中存根身份验证的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!