2018-04-12 08:07:44 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 14:09:03 -04:00
|
|
|
RSpec.describe ProjectCiCdSetting do
|
2021-02-09 04:09:19 -05:00
|
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
|
2019-05-30 02:40:53 -04:00
|
|
|
describe 'validations' do
|
2019-06-06 07:20:26 -04:00
|
|
|
it 'validates default_git_depth is between 0 and 1000 or nil' do
|
|
|
|
expect(subject).to validate_numericality_of(:default_git_depth)
|
|
|
|
.only_integer
|
|
|
|
.is_greater_than_or_equal_to(0)
|
|
|
|
.is_less_than_or_equal_to(1000)
|
|
|
|
.allow_nil
|
|
|
|
end
|
2019-05-30 02:40:53 -04:00
|
|
|
end
|
|
|
|
|
2020-02-17 04:08:52 -05:00
|
|
|
describe '#forward_deployment_enabled' do
|
|
|
|
it 'is true by default' do
|
|
|
|
expect(described_class.new.forward_deployment_enabled).to be_truthy
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2019-05-30 02:40:53 -04:00
|
|
|
describe '#default_git_depth' do
|
|
|
|
let(:default_value) { described_class::DEFAULT_GIT_DEPTH }
|
|
|
|
|
|
|
|
it 'sets default value for new records' do
|
|
|
|
project = create(:project)
|
|
|
|
|
|
|
|
expect(project.ci_cd_settings.default_git_depth).to eq(default_value)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not set default value if present' do
|
|
|
|
project = build(:project)
|
2019-06-06 07:08:01 -04:00
|
|
|
project.build_ci_cd_settings(default_git_depth: 0)
|
2019-05-30 02:40:53 -04:00
|
|
|
project.save!
|
|
|
|
|
2019-06-06 07:08:01 -04:00
|
|
|
expect(project.reload.ci_cd_settings.default_git_depth).to eq(0)
|
2019-05-30 02:40:53 -04:00
|
|
|
end
|
|
|
|
end
|
2021-02-09 04:09:19 -05:00
|
|
|
|
|
|
|
describe '#keep_latest_artifacts_available?' do
|
|
|
|
let(:attrs) { { keep_latest_artifact: project_enabled } }
|
|
|
|
let(:project_settings) { described_class.new(attrs) }
|
|
|
|
|
|
|
|
subject { project_settings.keep_latest_artifacts_available? }
|
|
|
|
|
|
|
|
context 'without application setting record' do
|
|
|
|
where(:project_enabled, :result_keep_latest_artifact) do
|
|
|
|
false | false
|
|
|
|
true | true
|
|
|
|
end
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
it { expect(subject).to eq(result_keep_latest_artifact) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with application setting record' do
|
|
|
|
where(:instance_enabled, :project_enabled, :result_keep_latest_artifact) do
|
|
|
|
false | false | false
|
|
|
|
false | true | false
|
|
|
|
true | false | false
|
|
|
|
true | true | true
|
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
Gitlab::CurrentSettings.current_application_settings.update!(keep_latest_artifact: instance_enabled)
|
|
|
|
end
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
it { expect(subject).to eq(result_keep_latest_artifact) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-04-12 08:07:44 -04:00
|
|
|
end
|