diff options
Diffstat (limited to 'spec/services/ci/create_pipeline_service_spec.rb')
-rw-r--r-- | spec/services/ci/create_pipeline_service_spec.rb | 30 |
1 files changed, 16 insertions, 14 deletions
diff --git a/spec/services/ci/create_pipeline_service_spec.rb b/spec/services/ci/create_pipeline_service_spec.rb index 9dc518be996..db4c2f5a047 100644 --- a/spec/services/ci/create_pipeline_service_spec.rb +++ b/spec/services/ci/create_pipeline_service_spec.rb @@ -93,6 +93,7 @@ RSpec.describe Ci::CreatePipelineService do let(:merge_request_1) do create(:merge_request, source_branch: 'feature', target_branch: "master", source_project: project) end + let(:merge_request_2) do create(:merge_request, source_branch: 'feature', target_branch: "v1.1.0", source_project: project) end @@ -512,7 +513,7 @@ RSpec.describe Ci::CreatePipelineService do it 'pull it from Auto-DevOps' do pipeline = execute_service expect(pipeline).to be_auto_devops_source - expect(pipeline.builds.map(&:name)).to match_array(%w[build code_quality eslint-sast test]) + expect(pipeline.builds.map(&:name)).to match_array(%w[build code_quality eslint-sast secret_detection_default_branch secrets-sast test]) end end @@ -905,6 +906,7 @@ RSpec.describe Ci::CreatePipelineService do stub_ci_pipeline_yaml_file(YAML.dump({ rspec: { script: 'rspec', retry: retry_value } })) + rspec_job.update!(options: { retry: retry_value }) end context 'as an integer' do @@ -912,8 +914,6 @@ RSpec.describe Ci::CreatePipelineService do it 'correctly creates builds with auto-retry value configured' do expect(pipeline).to be_persisted - expect(rspec_job.options_retry_max).to eq 2 - expect(rspec_job.options_retry_when).to eq ['always'] end end @@ -922,8 +922,6 @@ RSpec.describe Ci::CreatePipelineService do it 'correctly creates builds with auto-retry value configured' do expect(pipeline).to be_persisted - expect(rspec_job.options_retry_max).to eq 2 - expect(rspec_job.options_retry_when).to eq ['runner_system_failure'] end end end @@ -985,7 +983,6 @@ RSpec.describe Ci::CreatePipelineService do context 'with release' do shared_examples_for 'a successful release pipeline' do before do - stub_feature_flags(ci_release_generation: true) stub_ci_pipeline_yaml_file(YAML.dump(config)) end @@ -1695,16 +1692,23 @@ RSpec.describe Ci::CreatePipelineService do context 'when pipeline on feature is created' do let(:ref_name) { 'refs/heads/feature' } + shared_examples 'has errors' do + it 'contains the expected errors' do + expect(pipeline.builds).to be_empty + expect(pipeline.yaml_errors).to eq("test_a: needs 'build_a'") + expect(pipeline.error_messages.map(&:content)).to contain_exactly("test_a: needs 'build_a'") + expect(pipeline.errors[:base]).to contain_exactly("test_a: needs 'build_a'") + end + end + context 'when save_on_errors is enabled' do let(:pipeline) { execute_service(save_on_errors: true) } it 'does create a pipeline as test_a depends on build_a' do expect(pipeline).to be_persisted - expect(pipeline.builds).to be_empty - expect(pipeline.yaml_errors).to eq("test_a: needs 'build_a'") - expect(pipeline.messages.pluck(:content)).to contain_exactly("test_a: needs 'build_a'") - expect(pipeline.errors[:base]).to contain_exactly("test_a: needs 'build_a'") end + + it_behaves_like 'has errors' end context 'when save_on_errors is disabled' do @@ -1712,11 +1716,9 @@ RSpec.describe Ci::CreatePipelineService do it 'does not create a pipeline as test_a depends on build_a' do expect(pipeline).not_to be_persisted - expect(pipeline.builds).to be_empty - expect(pipeline.yaml_errors).to be_nil - expect(pipeline.messages).not_to be_empty - expect(pipeline.errors[:base]).to contain_exactly("test_a: needs 'build_a'") end + + it_behaves_like 'has errors' end end |