use*_*033 5 testing session controller rspec ruby-on-rails-4
在我的应用程序中,我有一个会话控制器。现在我想测试用户控制器,只有登录后才能访问该控制器。
我的问题是如何伪造会话。我已经尝试了很多,所以我希望你现在可以帮助我:
应用控制器:
helper_method :current_user
def authenticate_user
current_user
if @current_user
return true
else
redirect_to(:controller => 'sessions', :action => 'new')
return false
end
end
private
def current_user
@current_user ||= User.find(session[:user_id]) if session[:user_id]
end
Run Code Online (Sandbox Code Playgroud)
用户控制器具有:
before_filter :authenticate_user
Run Code Online (Sandbox Code Playgroud)
控制器测试:
describe "GET index" do
it "assigns all users as @users" do
user = FactoryGirl.create(:user)
@request.session[:user_id] = user.id
get 'users'
expect(@users.size).to eq(1)
end
end
Run Code Online (Sandbox Code Playgroud)
我也尝试过session[:user_id] = user.id并调试(在获取请求之后):
@current_user总是为零User.find(session[:user_id])返回正确的用户尝试controller代替@request:
user = FactoryGirl.create(:user)
controller.session[:user_id] = user.id
get 'users'
expect(@users.size).to eq(1)
Run Code Online (Sandbox Code Playgroud)
另外你@users在测试中定义了变量吗?大概应该是expect(User.count).to eq(1)