Commit 1844846a authored by Nick Thomas's avatar Nick Thomas

Merge branch '6111-geo-oauth-session-specs' into 'master'

Resolve "ee/spec/lib/gitlab/geo/oauth_session_spec.rb test doesn't actually do anything"

Closes #6111

See merge request gitlab-org/gitlab-ee!5896
parents 24914b88 dd8e7ede
...@@ -3,14 +3,14 @@ require 'spec_helper' ...@@ -3,14 +3,14 @@ require 'spec_helper'
describe Gitlab::Geo::OauthSession do describe Gitlab::Geo::OauthSession do
subject { described_class.new } subject { described_class.new }
let(:oauth_app) { FactoryBot.create(:doorkeeper_application) } let(:oauth_app) { FactoryBot.create(:doorkeeper_application) }
let(:oauth_return_to) { 'http://localhost:3000/oauth/geo/callback' } let(:oauth_return_to) { 'http://secondary/oauth/geo/callback' }
let(:dummy_state) { 'salt:hmac:return_to' } let(:dummy_state) { 'salt:hmac:return_to' }
let(:valid_state) { described_class.new(return_to: oauth_return_to).generate_oauth_state } let(:valid_state) { described_class.new(return_to: oauth_return_to).generate_oauth_state }
let(:access_token) { FactoryBot.create(:doorkeeper_access_token).token } let(:access_token) { FactoryBot.create(:doorkeeper_access_token).token }
before do before do
allow(subject).to receive(:oauth_app) { oauth_app } allow(subject).to receive(:oauth_app) { oauth_app }
allow(subject).to receive(:primary_node_url) { 'http://localhost:3001/' } allow(subject).to receive(:primary_node_url) { 'http://primary/' }
end end
describe '#oauth_state_valid?' do describe '#oauth_state_valid?' do
...@@ -107,31 +107,36 @@ describe Gitlab::Geo::OauthSession do ...@@ -107,31 +107,36 @@ describe Gitlab::Geo::OauthSession do
it 'returns a valid url' do it 'returns a valid url' do
expect(subject.authorize_url).to be_a String expect(subject.authorize_url).to be_a String
expect(subject.authorize_url).to include('http://localhost:3001/') expect(subject.authorize_url).to include('http://primary/')
end end
end end
describe '#authenticate_with_gitlab' do describe '#authenticate_with_gitlab' do
let(:response) { double } let(:api_url) { 'http://primary/api/v4/user' }
let(:user_json) { ActiveSupport::JSON.encode({ id: 555, email: 'user@example.com' }.as_json) }
before do
allow_any_instance_of(OAuth2::AccessToken).to receive(:get) { response }
end
context 'on success' do context 'on success' do
before do
stub_request(:get, api_url).to_return(
body: user_json,
headers: { 'Content-Type' => 'application/json' }
)
end
it 'returns hashed user data' do it 'returns hashed user data' do
allow(response).to receive(:status) { 200 } parsed_json = JSON.parse(user_json)
allow(response).to receive(:parsed) { attributes_for(:user) }
subject.authenticate_with_gitlab(access_token) expect(subject.authenticate_with_gitlab(access_token)).to eq(parsed_json)
end end
end end
context 'on invalid token' do context 'on invalid token' do
it 'raises exception' do before do
allow(response).to receive(:status) { 401 } stub_request(:get, api_url).to_return(status: [401, "Unauthorized"])
end
expect { subject.authenticate_with_gitlab(access_token) }.to raise_error it 'raises exception' do
expect { subject.authenticate_with_gitlab(access_token) }.to raise_error(OAuth2::Error)
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment