summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGrzegorz Bizon <grzesiek.bizon@gmail.com>2017-10-11 15:32:19 +0200
committerGrzegorz Bizon <grzesiek.bizon@gmail.com>2017-11-06 11:04:09 +0100
commit164b1df59025e9685e243dd89d943ff5b1122b44 (patch)
treea26685f9fa72e83320ff9d543f790afe449a076a
parente2828a60679495d716ed3824959794f4d5fbf5bb (diff)
downloadgitlab-ce-164b1df59025e9685e243dd89d943ff5b1122b44.tar.gz
Extract ensure stage service from commit status class
-rw-r--r--app/models/commit_status.rb30
-rw-r--r--app/services/ci/ensure_stage_service.rb39
-rw-r--r--spec/factories/commit_statuses.rb1
3 files changed, 43 insertions, 27 deletions
diff --git a/app/models/commit_status.rb b/app/models/commit_status.rb
index 12e187024dd..6b07dbdf3ea 100644
--- a/app/models/commit_status.rb
+++ b/app/models/commit_status.rb
@@ -50,13 +50,9 @@ class CommitStatus < ActiveRecord::Base
#
# These are pages deployments and external statuses.
#
- before_create do |status|
- next if status.stage_id.present? || importing?
-
- ensure_pipeline_stage! do |stage|
- status.run_after_commit do
- StageUpdateWorker.perform_async(stage.id)
- end
+ before_create unless: :importing? do
+ Ci::EnsureStageService.new(project, user).execute(self) do |stage|
+ self.run_after_commit { StageUpdateWorker.perform_async(stage.id) }
end
end
@@ -188,24 +184,4 @@ class CommitStatus < ActiveRecord::Base
v =~ /\d+/ ? v.to_i : v
end
end
-
- private
-
- def ensure_pipeline_stage!
- (find_stage || create_stage!).tap do |stage|
- self.stage_id = stage.id
-
- yield stage
- end
- end
-
- def find_stage
- pipeline.stages.find_by(name: stage)
- end
-
- def create_stage!
- Ci::Stage.create!(name: stage,
- pipeline: pipeline,
- project: project)
- end
end
diff --git a/app/services/ci/ensure_stage_service.rb b/app/services/ci/ensure_stage_service.rb
new file mode 100644
index 00000000000..dc2f49e8db1
--- /dev/null
+++ b/app/services/ci/ensure_stage_service.rb
@@ -0,0 +1,39 @@
+module Ci
+ ##
+ # We call this service everytime we persist a CI/CD job.
+ #
+ # In most cases a job should already have a stage assigned, but in cases it
+ # doesn't have we need to either find existing one or create a brand new
+ # stage.
+ #
+ class EnsureStageService < BaseService
+ def execute(build)
+ @build = build
+
+ return if build.stage_id.present?
+ return if build.invalid?
+
+ ensure_stage.tap do |stage|
+ build.stage_id = stage.id
+
+ yield stage if block_given?
+ end
+ end
+
+ private
+
+ def ensure_stage
+ find_stage || create_stage
+ end
+
+ def find_stage
+ @build.pipeline.stages.find_by(name: @build.stage)
+ end
+
+ def create_stage
+ Ci::Stage.create!(name: @build.stage,
+ pipeline: @build.pipeline,
+ project: @build.project)
+ end
+ end
+end
diff --git a/spec/factories/commit_statuses.rb b/spec/factories/commit_statuses.rb
index 169590deb8e..abbe37df90e 100644
--- a/spec/factories/commit_statuses.rb
+++ b/spec/factories/commit_statuses.rb
@@ -1,6 +1,7 @@
FactoryGirl.define do
factory :commit_status, class: CommitStatus do
name 'default'
+ stage 'test'
status 'success'
description 'commit status'
pipeline factory: :ci_pipeline_with_one_job