diff options
author | Shinya Maeda <shinya@gitlab.com> | 2017-07-28 00:33:41 +0900 |
---|---|---|
committer | Shinya Maeda <shinya@gitlab.com> | 2017-07-28 18:13:30 +0900 |
commit | 8c4c310d86d2481c6bb94b62a64ec56acd7e4735 (patch) | |
tree | 3a89eaf6e480e3e3569ad77cf128aac30e551e55 /app/services | |
parent | b59abf5b4495f00767c574c46e0cfed569204a85 (diff) | |
download | gitlab-ce-8c4c310d86d2481c6bb94b62a64ec56acd7e4735.tar.gz |
Revert "Move validate to begin/rescue block"
This reverts commit 5ec3b63bfc6f341df040ae08be4858c7181bcacf.
Diffstat (limited to 'app/services')
-rw-r--r-- | app/services/ci/create_pipeline_service.rb | 39 |
1 files changed, 14 insertions, 25 deletions
diff --git a/app/services/ci/create_pipeline_service.rb b/app/services/ci/create_pipeline_service.rb index 4c16d42f8bd..780331d0b4e 100644 --- a/app/services/ci/create_pipeline_service.rb +++ b/app/services/ci/create_pipeline_service.rb @@ -1,13 +1,5 @@ module Ci class CreatePipelineService < BaseService - class InsufficientConditionError < StandardError - attr_reader :pipeline - - def initialize(pipeline) - @pipeline = pipeline - end - end - attr_reader :pipeline def execute(source, ignore_skip_ci: false, save_on_errors: true, trigger_request: nil, schedule: nil) @@ -23,11 +15,13 @@ module Ci pipeline_schedule: schedule ) - begin - validate(current_user || trigger_request.trigger.owner, - ignore_skip_ci: ignore_skip_ci, - save_on_errors: save_on_errors) + result = validate(current_user || trigger_request.trigger.owner, + ignore_skip_ci: ignore_skip_ci, + save_on_errors: save_on_errors) + return result if result + + begin Ci::Pipeline.transaction do pipeline.save! @@ -37,13 +31,8 @@ module Ci .new(project, current_user) .execute(pipeline) end - - rescue InsufficientConditionError => e - return e.pipeline - rescue ActiveRecord::RecordInvalid => e return error("Failed to persist the pipeline: #{e}") - end update_merge_requests_head_pipeline @@ -59,30 +48,30 @@ module Ci def validate(triggering_user, ignore_skip_ci:, save_on_errors:) unless project.builds_enabled? - raise InsufficientConditionError, error('Pipeline is disabled') + return error('Pipeline is disabled') end unless allowed_to_trigger_pipeline?(triggering_user) if can?(triggering_user, :create_pipeline, project) - raise InsufficientConditionError, error("Insufficient permissions for protected ref '#{ref}'") + return error("Insufficient permissions for protected ref '#{ref}'") else - raise InsufficientConditionError, error('Insufficient permissions to create a new pipeline') + return error('Insufficient permissions to create a new pipeline') end end unless branch? || tag? - raise InsufficientConditionError, error('Reference not found') + return error('Reference not found') end unless commit - raise InsufficientConditionError, error('Commit not found') + return error('Commit not found') end unless pipeline.config_processor unless pipeline.ci_yaml_file - raise InsufficientConditionError, error("Missing #{pipeline.ci_yaml_file_path} file") + return error("Missing #{pipeline.ci_yaml_file_path} file") end - raise InsufficientConditionError, error(pipeline.yaml_errors, save: save_on_errors) + return error(pipeline.yaml_errors, save: save_on_errors) end if !ignore_skip_ci && skip_ci? @@ -91,7 +80,7 @@ module Ci end unless pipeline.has_stage_seeds? - raise InsufficientConditionError, error('No stages / jobs for this pipeline.') + return error('No stages / jobs for this pipeline.') end end |