如何在RSpec测试中为JSON API传递身份验证令牌?

时间:2016-05-30 10:56:59

标签: ruby-on-rails json rspec-rails

我正在尝试在Rails中向RSpec get 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

基于在线发现的一些推荐解决方案,我试过

  1. get '/api/v1/projects/1', format: :json, token: "123"

  2. get '/api/v1/projects/1', { 'HTTP-AUTHORIZATION' => 'Token "123"' }, format: :json

  3. get '/api/v1/projects/1', {:Authorization => "Token 123"}, format: :json

  4. 但似乎没有成功传递授权令牌。

    注意:#3中的样式在从外部应用程序发布时起作用,但在RSpec测试本身中不起作用。

    有没有人有这方面的经验并可以分享一些方向?

2 个答案:

答案 0 :(得分:8)

使用它像:

 get '/api/v1/projects/1', {}, { Authorization:  "Token 123"}

get是http方法,{}是空的参数,{ :Authorization => "Token 123"}标题

  

get(path,parameters = nil,headers_or_env = nil)

Documentation

其他方式:

before do
    # some code here
    @request.env['Authorization'] = "Token 123"
    get '/api/v1/projects/1', format: :json
end

答案 1 :(得分:1)

当我尝试这样的时候它起作用了

get '/api/v1/projects/1', as: :json, headers: {:Authorization => "Token 123"}