我正在尝试get
在Rails的RSpec JSON API测试中添加授权令牌。但是到目前为止,所有尝试都导致错误。问题似乎是令牌没有在请求中正确传递。
expected the response to have a success status code (2xx) but it was 401
当前代码:
Project_spec.rb(测试)
before do
@project = create(:project, :key => "123")
get '/api/v1/projects/1', {:Authorization => "Token 123"}, format: :json
end
it "returns correct status" do
expect( response ).to have_http_status(:success)
end
ProjectsController.rb
before_filter :restrict_access, :except => :create
def show
@project = Project.find(params[:id])
render json: @project
end
def restrict_access
authenticate_or_request_with_http_token do |token, options|
Project.exists?(key: token)
end
end
根据网上找到的一些推荐解决方案,我尝试了
get '/api/v1/projects/1', format: :json, token: "123"
get '/api/v1/projects/1', { 'HTTP-AUTHORIZATION' => 'Token "123"' }, format: :json
get '/api/v1/projects/1', {:Authorization => "Token 123"}, format: :json
但是似乎没有成功通过授权令牌的事情。
注意:从外部应用程序发布时,#3中的样式有效,但在RSpec测试本身中则无效。
是否有人对此有经验并可以分享一些指导?
像这样使用它:
get '/api/v1/projects/1', {}, { Authorization: "Token 123"}
get
是http方法,{}
一个空的参数,{ :Authorization => "Token 123"}
标头
get(路径,参数=零,headers_or_env =零)
另一种方式:
before do
# some code here
@request.env['Authorization'] = "Token 123"
get '/api/v1/projects/1', format: :json
end
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句