diff options
author | Shinya Maeda <shinya@gitlab.com> | 2017-07-27 15:52:55 +0900 |
---|---|---|
committer | Shinya Maeda <shinya@gitlab.com> | 2017-07-28 18:13:29 +0900 |
commit | 48389e9944d7914ca2027df379a523b493ca4245 (patch) | |
tree | 6d16e7d988c971ee322903bff7ea2bcc9332c8e3 /app/services/ci/create_pipeline_service.rb | |
parent | 19789154d3b900febdf8cff9991d3806e84065f4 (diff) | |
download | gitlab-ce-48389e9944d7914ca2027df379a523b493ca4245.tar.gz |
Fix pipeline
Diffstat (limited to 'app/services/ci/create_pipeline_service.rb')
-rw-r--r-- | app/services/ci/create_pipeline_service.rb | 30 |
1 files changed, 18 insertions, 12 deletions
diff --git a/app/services/ci/create_pipeline_service.rb b/app/services/ci/create_pipeline_service.rb index 9c6035601fd..4c16d42f8bd 100644 --- a/app/services/ci/create_pipeline_service.rb +++ b/app/services/ci/create_pipeline_service.rb @@ -1,6 +1,12 @@ module Ci class CreatePipelineService < BaseService - class ParameterValidationError < StandardError end + class InsufficientConditionError < StandardError + attr_reader :pipeline + + def initialize(pipeline) + @pipeline = pipeline + end + end attr_reader :pipeline @@ -32,8 +38,8 @@ module Ci .execute(pipeline) end - rescue ParameterValidationError => e - return e + rescue InsufficientConditionError => e + return e.pipeline rescue ActiveRecord::RecordInvalid => e return error("Failed to persist the pipeline: #{e}") @@ -53,39 +59,39 @@ module Ci def validate(triggering_user, ignore_skip_ci:, save_on_errors:) unless project.builds_enabled? - raise ParameterValidationError, error('Pipeline is disabled') + raise InsufficientConditionError, error('Pipeline is disabled') end unless allowed_to_trigger_pipeline?(triggering_user) if can?(triggering_user, :create_pipeline, project) - raise ParameterValidationError, error("Insufficient permissions for protected ref '#{ref}'") + raise InsufficientConditionError, error("Insufficient permissions for protected ref '#{ref}'") else - raise ParameterValidationError, error('Insufficient permissions to create a new pipeline') + raise InsufficientConditionError, error('Insufficient permissions to create a new pipeline') end end unless branch? || tag? - raise ParameterValidationError, error('Reference not found') + raise InsufficientConditionError, error('Reference not found') end unless commit - raise ParameterValidationError, error('Commit not found') + raise InsufficientConditionError, error('Commit not found') end unless pipeline.config_processor unless pipeline.ci_yaml_file - raise ParameterValidationError, error("Missing #{pipeline.ci_yaml_file_path} file") + raise InsufficientConditionError, error("Missing #{pipeline.ci_yaml_file_path} file") end - raise ParameterValidationError, error(pipeline.yaml_errors, save: save_on_errors) + raise InsufficientConditionError, error(pipeline.yaml_errors, save: save_on_errors) end if !ignore_skip_ci && skip_ci? pipeline.skip if save_on_errors - return pipeline + raise InsufficientConditionError, pipeline end unless pipeline.has_stage_seeds? - raise ParameterValidationError, error('No stages / jobs for this pipeline.') + raise InsufficientConditionError, error('No stages / jobs for this pipeline.') end end |