debian-mirror-gitlab/spec/lib/gitlab/ci/build/rules_spec.rb

259 lines
7.3 KiB
Ruby
Raw Normal View History

2019-12-26 22:10:19 +05:30
# frozen_string_literal: true
2019-12-04 20:38:33 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Ci::Build::Rules do
2019-12-04 20:38:33 +05:30
let(:pipeline) { create(:ci_pipeline) }
let(:ci_build) { build(:ci_build, pipeline: pipeline) }
let(:seed) do
double('build seed',
to_resource: ci_build,
2019-12-26 22:10:19 +05:30
variables: ci_build.scoped_variables_hash
2019-12-04 20:38:33 +05:30
)
end
2019-12-26 22:10:19 +05:30
let(:rules) { described_class.new(rule_list, default_when: 'on_success') }
2019-12-04 20:38:33 +05:30
describe '.new' do
let(:rules_ivar) { rules.instance_variable_get :@rule_list }
let(:default_when) { rules.instance_variable_get :@default_when }
context 'with no rules' do
let(:rule_list) { [] }
it 'sets @rule_list to an empty array' do
expect(rules_ivar).to eq([])
end
it 'sets @default_when to "on_success"' do
expect(default_when).to eq('on_success')
end
end
context 'with one rule' do
let(:rule_list) { [{ if: '$VAR == null', when: 'always' }] }
it 'sets @rule_list to an array of a single rule' do
expect(rules_ivar).to be_an(Array)
end
it 'sets @default_when to "on_success"' do
expect(default_when).to eq('on_success')
end
end
context 'with multiple rules' do
let(:rule_list) do
[
{ if: '$VAR == null', when: 'always' },
{ if: '$VAR == null', when: 'always' }
]
end
it 'sets @rule_list to an array of a single rule' do
expect(rules_ivar).to be_an(Array)
end
it 'sets @default_when to "on_success"' do
expect(default_when).to eq('on_success')
end
end
context 'with a specified default when:' do
let(:rule_list) { [{ if: '$VAR == null', when: 'always' }] }
2019-12-26 22:10:19 +05:30
let(:rules) { described_class.new(rule_list, default_when: 'manual') }
2019-12-04 20:38:33 +05:30
it 'sets @rule_list to an array of a single rule' do
expect(rules_ivar).to be_an(Array)
end
it 'sets @default_when to "manual"' do
expect(default_when).to eq('manual')
end
end
end
describe '#evaluate' do
subject { rules.evaluate(pipeline, seed) }
context 'with nil rules' do
let(:rule_list) { nil }
it { is_expected.to eq(described_class::Result.new('on_success')) }
context 'and when:manual set as the default' do
2019-12-26 22:10:19 +05:30
let(:rules) { described_class.new(rule_list, default_when: 'manual') }
2019-12-04 20:38:33 +05:30
it { is_expected.to eq(described_class::Result.new('manual')) }
end
end
context 'with no rules' do
let(:rule_list) { [] }
it { is_expected.to eq(described_class::Result.new('never')) }
context 'and when:manual set as the default' do
2019-12-26 22:10:19 +05:30
let(:rules) { described_class.new(rule_list, default_when: 'manual') }
2019-12-04 20:38:33 +05:30
it { is_expected.to eq(described_class::Result.new('never')) }
end
end
context 'with one rule without any clauses' do
2020-03-13 15:44:24 +05:30
let(:rule_list) { [{ when: 'manual', allow_failure: true }] }
2019-12-04 20:38:33 +05:30
2021-02-22 17:27:13 +05:30
it { is_expected.to eq(described_class::Result.new('manual', nil, true, nil)) }
2019-12-04 20:38:33 +05:30
end
context 'with one matching rule' do
let(:rule_list) { [{ if: '$VAR == null', when: 'always' }] }
it { is_expected.to eq(described_class::Result.new('always')) }
end
context 'with two matching rules' do
let(:rule_list) do
[
{ if: '$VAR == null', when: 'delayed', start_in: '1 day' },
{ if: '$VAR == null', when: 'always' }
]
end
it 'returns the value of the first matched rule in the list' do
expect(subject).to eq(described_class::Result.new('delayed', '1 day'))
end
end
context 'with a non-matching and matching rule' do
let(:rule_list) do
[
{ if: '$VAR =! null', when: 'delayed', start_in: '1 day' },
{ if: '$VAR == null', when: 'always' }
]
end
it { is_expected.to eq(described_class::Result.new('always')) }
end
context 'with a matching and non-matching rule' do
let(:rule_list) do
[
{ if: '$VAR == null', when: 'delayed', start_in: '1 day' },
{ if: '$VAR != null', when: 'always' }
]
end
it { is_expected.to eq(described_class::Result.new('delayed', '1 day')) }
end
context 'with non-matching rules' do
let(:rule_list) do
[
{ if: '$VAR != null', when: 'delayed', start_in: '1 day' },
{ if: '$VAR != null', when: 'always' }
]
end
it { is_expected.to eq(described_class::Result.new('never')) }
context 'and when:manual set as the default' do
2019-12-26 22:10:19 +05:30
let(:rules) { described_class.new(rule_list, default_when: 'manual') }
2019-12-04 20:38:33 +05:30
it 'does not return the default when:' do
expect(subject).to eq(described_class::Result.new('never'))
end
end
end
2020-03-13 15:44:24 +05:30
context 'with only allow_failure' do
context 'with matching rule' do
let(:rule_list) { [{ if: '$VAR == null', allow_failure: true }] }
2021-02-22 17:27:13 +05:30
it { is_expected.to eq(described_class::Result.new('on_success', nil, true, nil)) }
2020-03-13 15:44:24 +05:30
end
context 'with non-matching rule' do
let(:rule_list) { [{ if: '$VAR != null', allow_failure: true }] }
it { is_expected.to eq(described_class::Result.new('never')) }
end
end
2021-02-22 17:27:13 +05:30
context 'with variables' do
context 'with matching rule' do
let(:rule_list) { [{ if: '$VAR == null', variables: { MY_VAR: 'my var' } }] }
it { is_expected.to eq(described_class::Result.new('on_success', nil, nil, { MY_VAR: 'my var' })) }
end
end
2020-03-13 15:44:24 +05:30
end
describe 'Gitlab::Ci::Build::Rules::Result' do
let(:when_value) { 'on_success' }
let(:start_in) { nil }
let(:allow_failure) { nil }
2021-02-22 17:27:13 +05:30
let(:variables) { nil }
2020-03-13 15:44:24 +05:30
2021-02-22 17:27:13 +05:30
subject(:result) do
Gitlab::Ci::Build::Rules::Result.new(when_value, start_in, allow_failure, variables)
end
2020-03-13 15:44:24 +05:30
describe '#build_attributes' do
2021-02-22 17:27:13 +05:30
let(:seed_attributes) { {} }
subject(:build_attributes) do
result.build_attributes(seed_attributes)
end
2020-03-13 15:44:24 +05:30
it 'compacts nil values' do
2021-02-22 17:27:13 +05:30
is_expected.to eq(options: {}, when: 'on_success')
end
context 'when there are variables in rules' do
let(:variables) { { VAR1: 'new var 1', VAR3: 'var 3' } }
context 'when there are seed variables' do
let(:seed_attributes) do
{ yaml_variables: [{ key: 'VAR1', value: 'var 1', public: true },
{ key: 'VAR2', value: 'var 2', public: true }] }
end
it 'returns yaml_variables with override' do
is_expected.to include(
yaml_variables: [{ key: 'VAR1', value: 'new var 1', public: true },
{ key: 'VAR2', value: 'var 2', public: true },
{ key: 'VAR3', value: 'var 3', public: true }]
)
end
end
context 'when there is not seed variables' do
it 'does not return yaml_variables' do
is_expected.not_to have_key(:yaml_variables)
end
end
2020-03-13 15:44:24 +05:30
end
end
describe '#pass?' do
context "'when' is 'never'" do
let!(:when_value) { 'never' }
it 'returns false' do
2021-02-22 17:27:13 +05:30
expect(result.pass?).to eq(false)
2020-03-13 15:44:24 +05:30
end
end
context "'when' is 'on_success'" do
let!(:when_value) { 'on_success' }
it 'returns true' do
2021-02-22 17:27:13 +05:30
expect(result.pass?).to eq(true)
2020-03-13 15:44:24 +05:30
end
end
end
2019-12-04 20:38:33 +05:30
end
end