我正在尝试在Rails中为RSpec get
JSON API测试添加授权令牌。但到目前为止,所有尝试都会导致错误。问题似乎是令牌没有在请求中正确传递。如何在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测试本身中。
有没有人有这方面的经验,可以分享一些方向?
什么是空的则params的目的是什么? –
如果你忽略它,那么'{Authorization:“Token 123”}'识别为参数而不是头部。 –