2021-03-11 19:13:27 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Oauth::TokensController do
|
2021-09-04 01:27:46 +05:30
|
|
|
let(:cors_request_headers) { { 'Origin' => 'http://notgitlab.com' } }
|
|
|
|
let(:other_headers) { {} }
|
|
|
|
let(:headers) { cors_request_headers.merge(other_headers)}
|
2021-03-11 19:13:27 +05:30
|
|
|
|
2021-09-04 01:27:46 +05:30
|
|
|
shared_examples 'cross-origin POST request' do
|
|
|
|
it 'allows cross-origin requests' do
|
|
|
|
expect(response.headers['Access-Control-Allow-Origin']).to eq '*'
|
|
|
|
expect(response.headers['Access-Control-Allow-Methods']).to eq 'POST'
|
|
|
|
expect(response.headers['Access-Control-Allow-Headers']).to be_nil
|
|
|
|
expect(response.headers['Access-Control-Allow-Credentials']).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
shared_examples 'CORS preflight OPTIONS request' do
|
|
|
|
it 'returns 200' do
|
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'allows cross-origin requests' do
|
|
|
|
expect(response.headers['Access-Control-Allow-Origin']).to eq '*'
|
|
|
|
expect(response.headers['Access-Control-Allow-Methods']).to eq 'POST'
|
|
|
|
expect(response.headers['Access-Control-Allow-Headers']).to eq 'Authorization'
|
|
|
|
expect(response.headers['Access-Control-Allow-Credentials']).to be_nil
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST /oauth/token' do
|
|
|
|
before do
|
|
|
|
post '/oauth/token', headers: headers
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'cross-origin POST request'
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'OPTIONS /oauth/token' do
|
|
|
|
let(:other_headers) { { 'Access-Control-Request-Headers' => 'Authorization', 'Access-Control-Request-Method' => 'POST' } }
|
|
|
|
|
|
|
|
before do
|
|
|
|
options '/oauth/token', headers: headers
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'CORS preflight OPTIONS request'
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'POST /oauth/revoke' do
|
|
|
|
let(:other_headers) { { 'Content-Type' => 'application/x-www-form-urlencoded' } }
|
|
|
|
|
|
|
|
before do
|
|
|
|
post '/oauth/revoke', headers: headers, params: { token: '12345' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns 200' do
|
|
|
|
expect(response).to have_gitlab_http_status(:ok)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'cross-origin POST request'
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'OPTIONS /oauth/revoke' do
|
|
|
|
let(:other_headers) { { 'Access-Control-Request-Headers' => 'Authorization', 'Access-Control-Request-Method' => 'POST' } }
|
|
|
|
|
|
|
|
before do
|
|
|
|
options '/oauth/revoke', headers: headers
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'CORS preflight OPTIONS request'
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
|
|
|
end
|