在加载Rails控制台后,我应该如何登录用户?
Devise提供了一个测试助手,可以在测试中使用,我试着在控制台中使用。
>> include Devise::TestHelpers
>> helper.sign_in(User.first)
但我得到的是:
NoMethodError: undefined method `env' for nil:NilClass
总之,我想使用真正的devise helper而不是这个测试助手。有什么办法可以实现吗?
这是我能够做到的一个方法。
>> ApplicationController.allow_forgery_protection = false
>> app.post('/sign_in', {"user"=>{"login"=>"login", "password"=>"password"}})
那么你可以这样做。
>> app.get '/some_other_path_that_only_works_if_logged_in'
>> pp app.response.body
下面是另一个例子,它使用csrf令牌,验证用户,并发出POSTGET请求。
# get csrf token
app.get '/users/sign_in'
csrf_token = app.session[:_csrf_token]
# log in
app.post('/users/sign_in', {"authenticity_token"=>csrf_token, "user"=>{"email"=>"foo", "password"=>"bar"}})
# get new csrf token, as auth user
app.get ''
csrf_token = app.session[:_csrf_token]
# make a POST request
app.post '/some_request.json', {"some_value"=>"wee", "authenticity_token"=>csrf_token}
# make a GET request
app.get '/some_other_request.json'
你可以在你的控制器中添加一个动作,然后使用解释的技术。此处.
class MyController < ApplicationController
# POST /my_controller/become {'email': '[email protected]'}
def become
raise 'not in development environment' unless Rails.env == 'development'
sign_in User.find_by_email(params[:email])
end
end
需要注意的是,由于 Rails 5,params解析已经被改变为只接受一个参数和params(而不是params是第二个参数。
ActionDispatch::ParamsParser已被废弃,并从中间件堆栈中移除。要配置参数解析器,使用ActionDispatch::Request.parameter_parsers=。
因此,如果不给中间件打上补丁,前面的这些例子在现代Rails中将不再有效。 要使它们工作,只需在POST参数中包含如下参数。
app.post('/users/sign_in', {"user"=>{"email"=>"[email protected]", "password"=>"mycoolpassword"}})
<--不再有效
app.post('/users/sign_in', params: {"user"=>{"email"=>"[email protected]", "password"=>"mycoolpassword"}})
<-- 有效