Commit 1e6b5b87 authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch 'mk/geo-node-autosave-oauth-application' into 'master'

Geo: Persist OAuth callback changes for Alternate URL

See merge request gitlab-org/gitlab-ee!10358
parents 14af3ecf da04a906
...@@ -9,7 +9,7 @@ class GeoNode < ActiveRecord::Base ...@@ -9,7 +9,7 @@ class GeoNode < ActiveRecord::Base
# Array of repository storages to synchronize for selective sync by shards # Array of repository storages to synchronize for selective sync by shards
serialize :selective_sync_shards, Array # rubocop:disable Cop/ActiveRecordSerialize serialize :selective_sync_shards, Array # rubocop:disable Cop/ActiveRecordSerialize
belongs_to :oauth_application, class_name: 'Doorkeeper::Application', dependent: :destroy # rubocop: disable Cop/ActiveRecordDependent belongs_to :oauth_application, class_name: 'Doorkeeper::Application', dependent: :destroy, autosave: true # rubocop: disable Cop/ActiveRecordDependent
has_many :geo_node_namespace_links has_many :geo_node_namespace_links
has_many :namespaces, through: :geo_node_namespace_links has_many :namespaces, through: :geo_node_namespace_links
......
---
title: 'Geo: Persist OAuth callback changes for Alternate URL'
merge_request: 10358
author:
type: fixed
...@@ -16,7 +16,7 @@ describe GeoNode, type: :model do ...@@ -16,7 +16,7 @@ describe GeoNode, type: :model do
let(:api_version) { API::API.version } let(:api_version) { API::API.version }
context 'associations' do context 'associations' do
it { is_expected.to belong_to(:oauth_application).dependent(:destroy) } it { is_expected.to belong_to(:oauth_application).class_name('Doorkeeper::Application').dependent(:destroy).autosave(true) }
it { is_expected.to have_many(:geo_node_namespace_links) } it { is_expected.to have_many(:geo_node_namespace_links) }
it { is_expected.to have_many(:namespaces).through(:geo_node_namespace_links) } it { is_expected.to have_many(:namespaces).through(:geo_node_namespace_links) }
...@@ -196,6 +196,51 @@ describe GeoNode, type: :model do ...@@ -196,6 +196,51 @@ describe GeoNode, type: :model do
end end
end end
end end
context 'when saving' do
let(:oauth_application) { node.oauth_application }
context 'when url is changed' do
it "updates the associated OAuth application's redirect_uri" do
node.update!(url: 'http://modified-url')
expect(oauth_application.reload.redirect_uri).to eq('http://modified-url/oauth/geo/callback')
end
end
context 'when alternate_url is added' do
it "adds a callback URL to the associated OAuth application's redirect_uri" do
expected_redirect_uri = "#{oauth_application.redirect_uri}\nhttp://alternate-url/oauth/geo/callback"
node.update!(alternate_url: 'http://alternate-url')
expect(oauth_application.reload.redirect_uri).to eq(expected_redirect_uri)
end
end
context 'when alternate_url is modified' do
it "updates the alternate callback URL in the associated OAuth application's redirect_uri" do
node.update!(alternate_url: 'http://alternate-url')
oauth_application.update!(redirect_uri: "#{node.oauth_callback_url}\nhttp://alternate-url/oauth/geo/callback")
expected_redirect_uri = "#{node.oauth_callback_url}\nhttp://modified-alternate-url/oauth/geo/callback"
node.update!(alternate_url: 'http://modified-alternate-url')
expect(oauth_application.reload.redirect_uri).to eq(expected_redirect_uri)
end
end
context 'when alternate_url is cleared' do
it "removes the alternate callback URL in the associated OAuth application's redirect_uri" do
expected_redirect_uri = oauth_application.redirect_uri
oauth_application.update!(redirect_uri: "#{node.oauth_callback_url}\nhttp://alternate-url/oauth/geo/callback")
node.update!(alternate_url: nil)
expect(oauth_application.reload.redirect_uri).to eq(expected_redirect_uri)
end
end
end
end end
context 'cache expiration' do context 'cache expiration' do
......
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