Commit a615b544 authored by drew cimino's avatar drew cimino

Use table syntax for Ci::Processable validation spec conditions

parent 755601ec
...@@ -53,68 +53,31 @@ describe Ci::Processable do ...@@ -53,68 +53,31 @@ describe Ci::Processable do
describe 'validate presence of scheduling_type' do describe 'validate presence of scheduling_type' do
context 'on create' do context 'on create' do
let(:processable) do using RSpec::Parameterized::TableSyntax
build(
:ci_build, :created, project: project, pipeline: pipeline,
importing: importing, scheduling_type: nil
)
end
context 'when importing' do
let(:importing) { true }
context 'when validate_scheduling_type_of_processables is true' do subject { build(:ci_build, project: project, pipeline: pipeline, importing: importing) }
before do
stub_feature_flags(validate_scheduling_type_of_processables: true)
end
it 'does not validate' do where(:importing, :validate_scheduling_type_flag, :should_validate) do
expect(processable).to be_valid false | true | true
end false | false | false
end true | true | false
true | false | false
context 'when validate_scheduling_type_of_processables is false' do
before do
stub_feature_flags(validate_scheduling_type_of_processables: false)
end
it 'does not validate' do
expect(processable).to be_valid
end
end
end end
context 'when not importing' do with_them do
let(:importing) { false } before do
stub_feature_flags(validate_scheduling_type_of_processables: validate_scheduling_type_flag)
context 'when validate_scheduling_type_of_processables is true' do
before do
stub_feature_flags(validate_scheduling_type_of_processables: true)
end
it 'validates' do
expect(processable).not_to be_valid
end
end end
context 'when validate_scheduling_type_of_processables is false' do it 'validates on create' do
before do if should_validate
stub_feature_flags(validate_scheduling_type_of_processables: false) is_expected.to validate_presence_of(:scheduling_type).on(:create)
end else
is_expected.not_to validate_presence_of(:scheduling_type).on(:create)
it 'does not validate' do
expect(processable).to be_valid
end end
end end
end
end
context 'on update' do
let(:processable) { create(:ci_build, :created, project: project, pipeline: pipeline) }
it 'does not validate' do it { is_expected.not_to validate_presence_of(:scheduling_type).on(:update) }
processable.scheduling_type = nil
expect(processable).to be_valid
end end
end end
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment