debian-mirror-gitlab/qa/spec/service/docker_run/gitlab_runner_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

189 lines
5.3 KiB
Ruby
Raw Normal View History

2020-05-24 23:13:21 +05:30
# frozen_string_literal: true
module QA
2021-01-29 00:20:46 +05:30
RSpec.describe Service::DockerRun::GitlabRunner do
2020-05-24 23:13:21 +05:30
let(:runner_name) { 'test-runner' }
let(:address) { 'gitlab.test' }
let(:token) { 'abc123' }
let(:tags) { %w[qa test] }
subject do
described_class.new(runner_name).tap do |runner|
runner.address = address
runner.token = token
end
end
it 'defaults to run untagged' do
expect(subject.run_untagged).to be(true)
end
describe '#register!' do
let(:register) { subject.send(:register!) }
before do
allow(subject).to receive(:shell)
2022-06-21 17:19:12 +05:30
allow(subject).to receive(:wait_until_running_and_configured)
2020-05-24 23:13:21 +05:30
end
context 'defaults' do
before do
register
end
it 'runs non-interactively' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/ --non-interactive /)
2020-05-24 23:13:21 +05:30
end
it 'sets pertinent information' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--name #{runner_name} /)
expect(subject).to have_received_masked_shell_command(/--url #{subject.address} /)
expect(subject).to have_received_masked_shell_command(/--registration-token \S+/)
end
it 'masks the registration token' do
expect(subject).to have_received(:shell).with(/#{subject.token}/, mask_secrets: [subject.token])
2020-05-24 23:13:21 +05:30
end
it 'runs untagged' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--run-untagged=true /)
2020-05-24 23:13:21 +05:30
end
it 'has no tags' do
expect(subject.tags).to be_falsey
end
it 'runs daemonized' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/ -d /)
2020-05-24 23:13:21 +05:30
end
it 'cleans itself up' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/ --rm /)
2020-05-24 23:13:21 +05:30
end
end
context 'running untagged' do
before do
register
end
it 'passes --run-untagged=true' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--run-untagged=true /)
2020-05-24 23:13:21 +05:30
end
it 'does not pass tag list' do
2022-08-27 11:52:29 +05:30
expect(subject).not_to have_received_masked_shell_command(/--tag-list/)
2020-05-24 23:13:21 +05:30
end
end
context 'running tagged' do
context 'with only tags set' do
before do
subject.tags = tags
register
end
it 'does not pass --run-untagged' do
2022-08-27 11:52:29 +05:30
expect(subject).not_to have_received_masked_shell_command(/--run-untagged=true/)
2020-05-24 23:13:21 +05:30
end
it 'passes the tags with comma-separation' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--tag-list #{tags.join(',')} /)
2020-05-24 23:13:21 +05:30
end
end
context 'with specifying only run_untagged' do
before do
subject.run_untagged = false
end
it 'raises an error if tags are not specified' do
expect { register }.to raise_error(/must specify tags/i)
end
end
context 'when specifying contradicting variables' do
before do
subject.tags = tags
subject.run_untagged = true
end
it 'raises an error' do
expect { register }.to raise_error(/conflicting options/i)
end
end
end
context 'executors' do
it 'defaults to the shell executor' do
register
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--executor shell /)
2020-05-24 23:13:21 +05:30
end
context 'docker' do
before do
subject.executor = :docker
register
end
it 'specifies the docker executor' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--executor docker /)
2020-05-24 23:13:21 +05:30
end
it 'mounts the docker socket to the host runner' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(%r{-v /var/run/docker.sock:/var/run/docker.sock })
2020-05-24 23:13:21 +05:30
end
it 'runs in privileged mode' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--privileged /)
2020-05-24 23:13:21 +05:30
end
it 'has a default image' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--docker-image \b.+\b /)
2020-05-24 23:13:21 +05:30
end
it 'does not verify TLS' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--docker-tlsverify=false /)
2020-05-24 23:13:21 +05:30
end
it 'passes privileged mode' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--docker-privileged=true /)
2020-05-24 23:13:21 +05:30
end
it 'passes the host network' do
2022-08-27 11:52:29 +05:30
expect(subject).to have_received_masked_shell_command(/--docker-network-mode=#{subject.network}/)
2020-05-24 23:13:21 +05:30
end
end
end
end
describe '#tags=' do
before do
subject.tags = tags
end
it 'sets the tags' do
expect(subject.tags).to eq(tags)
end
it 'sets run_untagged' do
expect(subject.run_untagged).to be(false)
end
end
2022-08-27 11:52:29 +05:30
RSpec::Matchers.define "have_received_masked_shell_command" do |cmd|
match do |actual|
expect(actual).to have_received(:shell).with(cmd, mask_secrets: anything)
end
match_when_negated do |actual|
expect(actual).not_to have_received(:shell).with(cmd, mask_secrets: anything)
end
end
2020-05-24 23:13:21 +05:30
end
end