Class: Gitlab::QA::Scenario::Test::Instance::Airgapped

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

Instance Attribute Summary collapse

Instance Method Summary collapse

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

perform

Constructor Details

#initializeAirgapped

Returns a new instance of Airgapped.



12
13
14
15
16
17
18
19
20
21
22
# File 'lib/gitlab/qa/scenario/test/instance/airgapped.rb', line 12

def initialize
  # Uses https://docs.docker.com/engine/reference/commandline/network_create/#network-internal-mode
  @airgapped_network_name = 'airgapped'
  # Uses iptables to deny all network traffic, with a number of exceptions for required ports and IPs
  @iptables_restricted_network = Runtime::Env.docker_network
  @config = Component::GitalyCluster::GitalyClusterConfig.new(
    gitlab_name: "gitlab-airgapped-#{SecureRandom.hex(4)}",
    airgapped_network: true,
    network: airgapped_network_name
  )
end

Instance Attribute Details

#airgapped_network_nameObject (readonly)

Returns the value of attribute airgapped_network_name.



10
11
12
# File 'lib/gitlab/qa/scenario/test/instance/airgapped.rb', line 10

def airgapped_network_name
  @airgapped_network_name
end

#configObject (readonly)

Returns the value of attribute config.



10
11
12
# File 'lib/gitlab/qa/scenario/test/instance/airgapped.rb', line 10

def config
  @config
end

#gitlab_air_gap_commandsObject (readonly)

Returns the value of attribute gitlab_air_gap_commands.



10
11
12
# File 'lib/gitlab/qa/scenario/test/instance/airgapped.rb', line 10

def gitlab_air_gap_commands
  @gitlab_air_gap_commands
end

#iptables_restricted_networkObject (readonly)

Returns the value of attribute iptables_restricted_network.



10
11
12
# File 'lib/gitlab/qa/scenario/test/instance/airgapped.rb', line 10

def iptables_restricted_network
  @iptables_restricted_network
end

Instance Method Details

#perform(release, *rspec_args) ⇒ Object



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
# File 'lib/gitlab/qa/scenario/test/instance/airgapped.rb', line 24

def perform(release, *rspec_args)
  Component::Gitlab.perform do |gitlab|
    Component::GitalyCluster.perform do |cluster|
      cluster.config = @config
      cluster.release = release
      # we need to get an IP for praefect before proceeding so it cannot be run in parallel with gitlab
      cluster.instance(true).join
    end
    gitlab.name = config.gitlab_name
    gitlab.release = release
    gitlab.network = iptables_restricted_network # we use iptables to restrict access on the gitlab instance
    gitlab.runner_network = config.network
    gitlab.exec_commands = airgap_gitlab_commands
    gitlab.skip_availability_check = true
    gitlab.omnibus_configuration << gitlab_omnibus_configuration
    rspec_args << "--" unless rspec_args.include?('--')
    rspec_args << "--tag ~orchestrated"
    gitlab.instance do
      Component::Specs.perform do |specs|
        specs.suite = 'Test::Instance::Airgapped'
        specs.release = gitlab.release
        specs.network = gitlab.network
        specs.runner_network = gitlab.runner_network
        specs.args = [gitlab.address, *rspec_args]
      end
    end
  end
end