debian-mirror-gitlab/spec/lib/gitlab/ci/config/entry/image_spec.rb

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

208 lines
4.9 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2022-07-23 23:45:48 +05:30
require 'fast_spec_helper'
require 'support/helpers/stubbed_feature'
require 'support/helpers/stub_feature_flags'
2016-08-24 12:49:21 +05:30
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Ci::Config::Entry::Image do
2022-07-23 23:45:48 +05:30
include StubFeatureFlags
before do
stub_feature_flags(ci_docker_image_pull_policy: true)
2022-08-13 15:12:31 +05:30
entry.compose!
2022-07-23 23:45:48 +05:30
end
2016-08-24 12:49:21 +05:30
let(:entry) { described_class.new(config) }
2017-09-10 17:25:29 +05:30
context 'when configuration is a string' do
2022-06-21 17:19:12 +05:30
let(:config) { 'image:1.0' }
2016-08-24 12:49:21 +05:30
2017-09-10 17:25:29 +05:30
describe '#value' do
it 'returns image hash' do
2022-06-21 17:19:12 +05:30
expect(entry.value).to eq({ name: 'image:1.0' })
2016-08-24 12:49:21 +05:30
end
2017-09-10 17:25:29 +05:30
end
describe '#errors' do
it 'does not append errors' do
expect(entry.errors).to be_empty
end
end
describe '#valid?' do
it 'is valid' do
expect(entry).to be_valid
end
end
describe '#image' do
it "returns image's name" do
2022-06-21 17:19:12 +05:30
expect(entry.name).to eq 'image:1.0'
2017-09-10 17:25:29 +05:30
end
end
2016-08-24 12:49:21 +05:30
2017-09-10 17:25:29 +05:30
describe '#entrypoint' do
it "returns image's entrypoint" do
expect(entry.entrypoint).to be_nil
2016-08-24 12:49:21 +05:30
end
2017-09-10 17:25:29 +05:30
end
2019-07-07 11:18:12 +05:30
describe '#ports' do
it "returns image's ports" do
expect(entry.ports).to be_nil
end
end
2022-07-23 23:45:48 +05:30
describe '#pull_policy' do
it "returns nil" do
expect(entry.pull_policy).to be_nil
end
end
2017-09-10 17:25:29 +05:30
end
2016-08-24 12:49:21 +05:30
2017-09-10 17:25:29 +05:30
context 'when configuration is a hash' do
2022-06-21 17:19:12 +05:30
let(:config) { { name: 'image:1.0', entrypoint: %w(/bin/sh run) } }
2017-09-10 17:25:29 +05:30
describe '#value' do
it 'returns image hash' do
expect(entry.value).to eq(config)
2016-08-24 12:49:21 +05:30
end
end
2017-09-10 17:25:29 +05:30
describe '#errors' do
it 'does not append errors' do
expect(entry.errors).to be_empty
end
end
describe '#valid?' do
it 'is valid' do
expect(entry).to be_valid
end
end
2016-08-24 12:49:21 +05:30
2017-09-10 17:25:29 +05:30
describe '#image' do
it "returns image's name" do
2022-06-21 17:19:12 +05:30
expect(entry.name).to eq 'image:1.0'
2016-08-24 12:49:21 +05:30
end
2017-09-10 17:25:29 +05:30
end
describe '#entrypoint' do
it "returns image's entrypoint" do
expect(entry.entrypoint).to eq %w(/bin/sh run)
end
end
2019-07-07 11:18:12 +05:30
context 'when configuration has ports' do
let(:ports) { [{ number: 80, protocol: 'http', name: 'foobar' }] }
2022-06-21 17:19:12 +05:30
let(:config) { { name: 'image:1.0', entrypoint: %w(/bin/sh run), ports: ports } }
2021-02-22 17:27:13 +05:30
let(:entry) { described_class.new(config, with_image_ports: image_ports) }
2019-07-07 11:18:12 +05:30
let(:image_ports) { false }
context 'when with_image_ports metadata is not enabled' do
describe '#valid?' do
it 'is not valid' do
expect(entry).not_to be_valid
expect(entry.errors).to include("image config contains disallowed keys: ports")
end
end
end
context 'when with_image_ports metadata is enabled' do
let(:image_ports) { true }
describe '#valid?' do
it 'is valid' do
expect(entry).to be_valid
end
end
describe '#ports' do
it "returns image's ports" do
expect(entry.ports).to eq ports
end
end
end
end
2022-07-23 23:45:48 +05:30
context 'when configuration has pull_policy' do
let(:config) { { name: 'image:1.0', pull_policy: 'if-not-present' } }
describe '#valid?' do
it 'is valid' do
expect(entry).to be_valid
end
context 'when the feature flag ci_docker_image_pull_policy is disabled' do
before do
stub_feature_flags(ci_docker_image_pull_policy: false)
2022-08-13 15:12:31 +05:30
entry.compose!
2022-07-23 23:45:48 +05:30
end
it 'is not valid' do
expect(entry).not_to be_valid
expect(entry.errors).to include('image config contains unknown keys: pull_policy')
end
end
end
describe '#value' do
it "returns value" do
expect(entry.value).to eq(
name: 'image:1.0',
pull_policy: ['if-not-present']
)
end
context 'when the feature flag ci_docker_image_pull_policy is disabled' do
before do
stub_feature_flags(ci_docker_image_pull_policy: false)
2022-08-13 15:12:31 +05:30
entry.compose!
2022-07-23 23:45:48 +05:30
end
it 'is not valid' do
expect(entry.value).to eq(
name: 'image:1.0'
)
end
end
end
end
2017-09-10 17:25:29 +05:30
end
context 'when entry value is not correct' do
2022-06-21 17:19:12 +05:30
let(:config) { ['image:1.0'] }
2017-09-10 17:25:29 +05:30
describe '#errors' do
it 'saves errors' do
2019-07-07 11:18:12 +05:30
expect(entry.errors.first)
.to match /config should be a hash or a string/
2017-09-10 17:25:29 +05:30
end
end
describe '#valid?' do
it 'is not valid' do
expect(entry).not_to be_valid
end
end
end
context 'when unexpected key is specified' do
2022-06-21 17:19:12 +05:30
let(:config) { { name: 'image:1.0', non_existing: 'test' } }
2017-09-10 17:25:29 +05:30
describe '#errors' do
it 'saves errors' do
2019-07-07 11:18:12 +05:30
expect(entry.errors.first)
.to match /config contains unknown keys: non_existing/
2017-09-10 17:25:29 +05:30
end
end
2016-08-24 12:49:21 +05:30
2017-09-10 17:25:29 +05:30
describe '#valid?' do
it 'is not valid' do
expect(entry).not_to be_valid
2016-08-24 12:49:21 +05:30
end
end
end
end