travis-api/spec/unit/middleware/scope_check_spec.rb
2012-12-12 17:11:25 +01:00

86 lines
2.3 KiB
Ruby

require 'spec_helper'
describe Travis::Api::App::Middleware::ScopeCheck do
include Travis::Testing::Stubs
let :access_token do
Travis::Api::App::AccessToken.create(user: user, scope: :foo, app_id: -1)
end
before do
mock_app do
use Travis::Api::App::Middleware::ScopeCheck
get('/') { 'ok' }
get('/token') { env['travis.access_token'].to_s }
end
User.stubs(:find).with(user.id).returns(user)
end
it 'lets through requests without a token' do
get('/').should be_ok
body.should == 'ok'
headers['X-OAuth-Scopes'].should_not == 'foo'
end
describe 'sets associated scope properly' do
it 'accepts Authorization token header' do
get('/', {}, 'HTTP_AUTHORIZATION' => "token #{access_token}").should be_ok
headers['X-OAuth-Scopes'].should == 'foo'
end
it 'accepts basic auth' do
authorize access_token.to_s, 'x'
get('/').should be_ok
headers['X-OAuth-Scopes'].should == 'foo'
end
it 'accepts query parameters' do
get('/', access_token: access_token.to_s).should be_ok
headers['X-OAuth-Scopes'].should == 'foo'
end
end
describe 'with travis token' do
let(:travis_token) { stub_travis_token(user: user) }
let(:token) { travis_token.token }
before do
Token.stubs(:find_by_token).with(travis_token.token).returns(travis_token)
Token.stubs(:find_by_token).with("invalid").returns(nil)
end
it 'accepts a valid travis token' do
get('/', token: token).should be_ok
end
it 'rejects an invalid travis token' do
get('/', token: token)
headers['X-OAuth-Scopes'].should == 'travis_token'
end
it 'sets the scope to travis_token' do
get('/', token: "invalid").should_not be_ok
end
end
describe 'reject requests with an invalide token' do
it 'rejects Authorization token header' do
get('/', {}, 'HTTP_AUTHORIZATION' => "token foo").should_not be_ok
end
it 'rejects basic auth' do
authorize 'foo', 'x'
get('/').should_not be_ok
end
it 'rejects query parameters' do
get('/', access_token: 'foo').should_not be_ok
end
end
it 'sets env["travis.access_token"]' do
authorize access_token.to_s, 'x'
get('/token').body.should == access_token.to_s
end
end