From f7014cd5bc776f9829818e535baf9db70387a416 Mon Sep 17 00:00:00 2001 From: Lin Jen-Shin Date: Thu, 6 Apr 2017 03:23:36 +0800 Subject: [PATCH] Add a test to make sure it's not auto-canceling whenever the feature is disabled in the project. --- .../ci/create_pipeline_service_spec.rb | 34 +++++++++++++------ 1 file changed, 24 insertions(+), 10 deletions(-) diff --git a/spec/services/ci/create_pipeline_service_spec.rb b/spec/services/ci/create_pipeline_service_spec.rb index a3330367f96..fa5014cee07 100644 --- a/spec/services/ci/create_pipeline_service_spec.rb +++ b/spec/services/ci/create_pipeline_service_spec.rb @@ -21,6 +21,12 @@ describe Ci::CreatePipelineService, services: true do context 'valid params' do let(:pipeline) { execute_service } + let(:pipeline_on_previous_commit) do + execute_service( + after: previous_commit_sha_from_ref('master') + ) + end + it { expect(pipeline).to be_kind_of(Ci::Pipeline) } it { expect(pipeline).to be_valid } it { expect(pipeline).to eq(project.pipelines.last) } @@ -29,20 +35,10 @@ describe Ci::CreatePipelineService, services: true do it { expect(pipeline.builds.first).to be_kind_of(Ci::Build) } context 'auto-cancel enabled' do - let(:pipeline_on_previous_commit) do - execute_service( - after: previous_commit_sha_from_ref('master') - ) - end - before do project.update(auto_cancel_pending_pipelines: 'enabled') end - def previous_commit_sha_from_ref(ref) - project.commit(ref).parent.sha - end - it 'does not cancel HEAD pipeline' do pipeline pipeline_on_previous_commit @@ -81,6 +77,24 @@ describe Ci::CreatePipelineService, services: true do expect(pending_pipeline.reload).to have_attributes(status: 'pending', auto_canceled_by_id: nil) end end + + context 'auto-cancel disabled' do + before do + project.update(auto_cancel_pending_pipelines: 'disabled') + end + + it 'does not auto cancel pending non-HEAD pipelines' do + pipeline_on_previous_commit + pipeline + + expect(pipeline_on_previous_commit.reload) + .to have_attributes(status: 'pending', auto_canceled_by_id: nil) + end + end + + def previous_commit_sha_from_ref(ref) + project.commit(ref).parent.sha + end end context "skip tag if there is no build for it" do