summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGrzegorz Bizon <grzesiek.bizon@gmail.com>2017-03-03 15:13:50 +0100
committerGrzegorz Bizon <grzesiek.bizon@gmail.com>2017-03-06 10:04:04 +0100
commitd87132b46344b460bb8cba87df48218f65df29f3 (patch)
tree1ff6f0e7aff661daef37635a12c16622b1f2e6cd
parent53fcede5c0837eb53dcf67a9abf7d7b779bd1e25 (diff)
downloadgitlab-ce-d87132b46344b460bb8cba87df48218f65df29f3.tar.gz
Always actionize build when it is a manual action
Do not skip manual actions even if actions are optional.
-rw-r--r--app/services/ci/process_pipeline_service.rb7
-rw-r--r--spec/services/ci/process_pipeline_service_spec.rb72
2 files changed, 51 insertions, 28 deletions
diff --git a/app/services/ci/process_pipeline_service.rb b/app/services/ci/process_pipeline_service.rb
index c70b75cc577..2935d00c075 100644
--- a/app/services/ci/process_pipeline_service.rb
+++ b/app/services/ci/process_pipeline_service.rb
@@ -35,11 +35,8 @@ module Ci
def process_build(build, current_status)
if valid_statuses_for_when(build.when).include?(current_status)
- build.enqueue
+ build.action? ? build.actionize : build.enqueue
true
- elsif build.action? && build.barrier?
- build.actionize
- false
else
build.skip
false
@@ -54,6 +51,8 @@ module Ci
%w[failed]
when 'always'
%w[success failed skipped]
+ when 'manual'
+ %w[success]
else
[]
end
diff --git a/spec/services/ci/process_pipeline_service_spec.rb b/spec/services/ci/process_pipeline_service_spec.rb
index b0cd3aac83b..30b173642e7 100644
--- a/spec/services/ci/process_pipeline_service_spec.rb
+++ b/spec/services/ci/process_pipeline_service_spec.rb
@@ -73,7 +73,7 @@ describe Ci::ProcessPipelineService, '#execute', :services do
create_build('deploy', stage_idx: 3)
create_build('production', stage_idx: 3, when: 'manual', allow_failure: true)
create_build('cleanup', stage_idx: 4, when: 'always')
- create_build('clear cache', stage_idx: 4, when: 'manual', allow_failure: true)
+ create_build('clear:cache', stage_idx: 4, when: 'manual', allow_failure: true)
end
context 'when builds are successful' do
@@ -89,17 +89,17 @@ describe Ci::ProcessPipelineService, '#execute', :services do
succeed_running_or_pending
- expect(builds_names).to eq %w(build test deploy)
- expect(builds_statuses).to eq %w(success success pending)
+ expect(builds_names).to eq %w(build test deploy production)
+ expect(builds_statuses).to eq %w(success success pending manual)
succeed_running_or_pending
- expect(builds_names).to eq %w(build test deploy cleanup)
- expect(builds_statuses).to eq %w(success success success pending)
+ expect(builds_names).to eq %w(build test deploy production cleanup clear:cache)
+ expect(builds_statuses).to eq %w(success success success manual pending manual)
succeed_running_or_pending
- expect(builds_statuses).to eq %w(success success success success)
+ expect(builds_statuses).to eq %w(success success success manual success manual)
expect(pipeline.reload.status).to eq 'success'
end
end
@@ -174,18 +174,18 @@ describe Ci::ProcessPipelineService, '#execute', :services do
succeed_running_or_pending
- expect(builds_names).to eq %w(build test deploy)
- expect(builds_statuses).to eq %w(success success pending)
+ expect(builds_names).to eq %w(build test deploy production)
+ expect(builds_statuses).to eq %w(success success pending manual)
fail_running_or_pending
- expect(builds_names).to eq %w(build test deploy cleanup)
- expect(builds_statuses).to eq %w(success success failed pending)
+ expect(builds_names).to eq %w(build test deploy production cleanup)
+ expect(builds_statuses).to eq %w(success success failed manual pending)
succeed_running_or_pending
- expect(builds_statuses).to eq %w(success success failed success)
- expect(pipeline.reload.status).to eq('failed')
+ expect(builds_statuses).to eq %w(success success failed manual success)
+ expect(pipeline.reload).to be_failed
end
end
@@ -204,7 +204,9 @@ describe Ci::ProcessPipelineService, '#execute', :services do
cancel_running_or_pending
expect(builds.running_or_pending).to be_empty
- expect(pipeline.reload.status).to eq 'canceled'
+ expect(builds_names).to eq %w[build test]
+ expect(builds_statuses).to eq %w[success canceled]
+ expect(pipeline.reload).to be_canceled
end
end
@@ -243,7 +245,7 @@ describe Ci::ProcessPipelineService, '#execute', :services do
end
it 'starts from the second stage' do
- expect(all_builds_statuses).to eq %w[skipped pending created]
+ expect(all_builds_statuses).to eq %w[manual pending created]
end
end
@@ -261,7 +263,7 @@ describe Ci::ProcessPipelineService, '#execute', :services do
builds.first.success
- expect(all_builds_statuses).to eq(%w[success skipped pending])
+ expect(all_builds_statuses).to eq(%w[success manual pending])
end
end
end
@@ -275,18 +277,40 @@ describe Ci::ProcessPipelineService, '#execute', :services do
create_build('production:test', stage_idx: 4, when: 'always')
end
- it 'blocks pipeline on stage with first manual action' do
- process_pipeline
+ context 'when first stage succeeds' do
+ it 'blocks pipeline on stage with first manual action' do
+ process_pipeline
+
+ expect(builds_names).to eq %w[code:test]
+ expect(builds_statuses).to eq %w[pending]
+ expect(pipeline.reload.status).to eq 'pending'
+
+ succeed_running_or_pending
+
+ expect(builds_names).to eq %w[code:test staging:deploy]
+ expect(builds_statuses).to eq %w[success manual]
+ expect(pipeline.reload).to be_manual
+ end
+ end
+
+ context 'when first stage fails' do
+ it 'does not take blocking action into account' do
+ process_pipeline
+
+ expect(builds_names).to eq %w[code:test]
+ expect(builds_statuses).to eq %w[pending]
+ expect(pipeline.reload.status).to eq 'pending'
- expect(builds_names).to eq %w[code:test]
- expect(builds_statuses).to eq %w[pending]
- expect(pipeline.reload.status).to eq 'pending'
+ fail_running_or_pending
+
+ expect(builds_names).to eq %w[code:test production:test]
+ expect(builds_statuses).to eq %w[failed pending]
- succeed_running_or_pending
+ succeed_running_or_pending
- expect(builds_names).to eq %w[code:test staging:deploy]
- expect(builds_statuses).to eq %w[success manual]
- expect(pipeline.reload).to be_manual
+ expect(builds_statuses).to eq %w[failed success]
+ expect(pipeline.reload).to be_failed
+ end
end
end