我有一个资源,其中新操作需要用户登录才能查看。如果用户在未登录的情况下尝试创建新资源,他们将被重定向(302'd)到登录页面。我的功能测试如下所示:
test "should not get new unless logged in" do
get :new
assert_response :redirect
end
堆栈跟踪看起来像这样:
ArgumentError: uncaught throw :warden
/.../gems/warden-1.1.1/lib/warden/proxy.rb:114:in `throw'
/.../gems/ruby-1.9.2-p318/gems/warden-1.1.1/lib/warden/proxy.rb:114:in `authenticate!'
/.../gems/ruby-1.9.2-p318/gems/devise-2.0.4/lib/devise/controllers/helpers.rb:48:in `authenticate_user!'
在新操作之前,我有一个 before_filter 来验证用户。
我明白为什么要进行身份验证用户!失败了,但我不明白为什么它会抛出错误。它不应该像在 webapp 中那样运行吗?将用户重定向到登录页面?
谢谢。