Commit 62e11948 authored by Mark Lapierre's avatar Mark Lapierre

Run gitlab-ctl reconfigure after replication

On the Geo secondary, we need to re-run
gitlab-ctl reconfigure on the secondary,
otherwise FDW does not work.

Re-order Geo QA secondary functions
So they more closely match execution order.

Unquarantine the Geo attachment test
parent f3ba070a
...@@ -34,6 +34,7 @@ module QA ...@@ -34,6 +34,7 @@ module QA
Geo::Secondary.act do Geo::Secondary.act do
replicate_database replicate_database
reconfigure
wait_for_services wait_for_services
authorize authorize
end end
...@@ -106,19 +107,6 @@ module QA ...@@ -106,19 +107,6 @@ module QA
@name = QA::Runtime::Scenario.geo_secondary_name @name = QA::Runtime::Scenario.geo_secondary_name
end end
def authorize
# Provide OAuth authorization now so that tests don't have to
QA::Runtime::Browser.visit(:geo_secondary, QA::Page::Main::Login) do
QA::Page::Main::Login.perform(&:sign_in_using_credentials)
QA::Page::Main::OAuth.perform do |oauth|
oauth.authorize! if oauth.needs_authorization?
end
# Log out so that tests are in an initially unauthenticated state
QA::Page::Main::Menu.perform(&:sign_out)
end
end
def replicate_database def replicate_database
puts 'Starting Geo replication on secondary node ...' puts 'Starting Geo replication on secondary node ...'
...@@ -133,6 +121,17 @@ module QA ...@@ -133,6 +121,17 @@ module QA
end end
end end
def reconfigure
# Without this step, the /var/opt/gitlab/postgresql/data/pg_hba.conf
# that is left behind from 'gitlab_ctl "replicate-geo-database ..'
# does not allow FDW to work.
puts 'Reconfiguring ...'
QA::Service::Omnibus.new(@name).act do
gitlab_ctl 'reconfigure'
end
end
def wait_for_services def wait_for_services
puts 'Waiting until secondary node services are ready ...' puts 'Waiting until secondary node services are ready ...'
...@@ -156,6 +155,19 @@ module QA ...@@ -156,6 +155,19 @@ module QA
raise "Secondary node did not start correctly in #{Time.now - start} seconds!" raise "Secondary node did not start correctly in #{Time.now - start} seconds!"
end end
end end
def authorize
# Provide OAuth authorization now so that tests don't have to
QA::Runtime::Browser.visit(:geo_secondary, QA::Page::Main::Login) do
QA::Page::Main::Login.perform(&:sign_in_using_credentials)
QA::Page::Main::OAuth.perform do |oauth|
oauth.authorize! if oauth.needs_authorization?
end
# Log out so that tests are in an initially unauthenticated state
QA::Page::Main::Menu.perform(&:sign_out)
end
end
end end
end end
end end
......
# frozen_string_literal: true # frozen_string_literal: true
module QA module QA
# https://gitlab.com/gitlab-org/quality/nightly/issues/109 context 'Geo', :orchestrated, :geo do
context 'Geo', :orchestrated, :geo, :quarantine do
describe 'GitLab Geo attachment replication' do describe 'GitLab Geo attachment replication' do
let(:file_to_attach) { File.absolute_path(File.join('spec', 'fixtures', 'banana_sample.gif')) } let(:file_to_attach) { File.absolute_path(File.join('spec', 'fixtures', 'banana_sample.gif')) }
......
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