Class: Gitlab::QA::Scenario::Test::Integration::Geo

Inherits:
Gitlab::QA::Scenario::Template show all
Defined in:
lib/gitlab/qa/scenario/test/integration/geo.rb

Instance Method Summary collapse

Methods inherited from Gitlab::QA::Scenario::Template

perform

Instance Method Details

#perform(release, *rspec_args) ⇒ Object

rubocop:disable Lint/MissingCopEnableDirective

Raises:

  • (ArgumentError)


10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
# File 'lib/gitlab/qa/scenario/test/integration/geo.rb', line 10

def perform(release, *rspec_args)
  release = QA::Release.new(release)

  raise ArgumentError, 'Geo is EE only!' unless release.ee?

  Runtime::Env.require_license!

  Component::Gitlab.perform do |primary|
    primary.release = release
    primary.name = 'gitlab-primary'
    primary.network = 'geo'
    primary.seed_admin_token = false
    primary.omnibus_configuration << <<~OMNIBUS
      gitlab_rails['db_key_base'] = '4dd58204865eb41bca93bd38131d51cc';
      geo_primary_role['enable'] = true;
      gitlab_rails['db_password'] = 'mypass';
      gitlab_rails['db_pool'] = 5;
      gitlab_rails['geo_node_name'] = '#{primary.name}';
      gitlab_rails['monitoring_whitelist'] = ['0.0.0.0/0'];
      gitlab_rails['packages_enabled'] = true;
      postgresql['listen_address'] = '0.0.0.0';
      postgresql['max_replication_slots'] = 1;
      postgresql['md5_auth_cidr_addresses'] = ['0.0.0.0/0'];
      postgresql['sql_user_password'] = 'e1d1469ec5f533651918b4567a3ed1ae';
      postgresql['trust_auth_cidr_addresses'] = ['0.0.0.0/0','0.0.0.0/0'];
      sidekiq['concurrency'] = 2;
      puma['worker_processes'] = 2;
    OMNIBUS
    primary.exec_commands = fast_ssh_key_lookup_commands + QA::Scenario::CLICommands.git_lfs_install_commands

    primary.instance do
      Component::Gitlab.perform do |secondary|
        secondary.release = release
        secondary.name = 'gitlab-secondary'
        secondary.network = 'geo'
        secondary.omnibus_configuration << <<~OMNIBUS
          geo_secondary['db_fdw'] = true;
          geo_secondary_role['enable'] = true;
          gitlab_rails['db_key_base'] = '4dd58204865eb41bca93bd38131d51cc';
          gitlab_rails['db_password'] = 'mypass';
          gitlab_rails['db_pool'] = 5;
          gitlab_rails['geo_node_name'] = '#{secondary.name}';
          gitlab_rails['monitoring_whitelist'] = ['0.0.0.0/0'];
          gitlab_rails['packages_enabled'] = true;
          postgresql['listen_address'] = '0.0.0.0';
          postgresql['md5_auth_cidr_addresses'] = ['0.0.0.0/0'];
          postgresql['sql_user_password'] = 'e1d1469ec5f533651918b4567a3ed1ae';
          sidekiq['concurrency'] = 2;
          puma['worker_processes'] = 2;
        OMNIBUS
        secondary.exec_commands += fast_ssh_key_lookup_commands + QA::Scenario::CLICommands.git_lfs_install_commands

        secondary.act do
          # TODO, we do not wait for secondary to start because of
          # https://gitlab.com/gitlab-org/gitlab-ee/issues/3999
          #
          # rubocop:disable Style/Semicolon
          prepare; start; reconfigure; process_exec_commands

          # shellout to instance specs
          Runtime::Logger.info('Running Geo primary / secondary specs!')

          Component::Specs.perform do |specs|
            specs.suite = 'QA::EE::Scenario::Test::Geo'
            specs.release = release
            specs.network = 'geo'
            specs.args = [
              '--primary-address', primary.address,
              '--primary-name', primary.name,
              '--secondary-address', secondary.address,
              '--secondary-name', secondary.name,
              *rspec_args
            ]
          end

          teardown
        end
      end
    end
  end
end