00f0d356b7
Introduces the concept of Prerequisites for a CI build. If a build has unmet prerequisites it will go through the :preparing state before being made available to a runner. There are no actual prerequisites yet, so current behaviour is unchanged.
57 lines
1.4 KiB
Ruby
57 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Gitlab
|
|
module Ci
|
|
module Status
|
|
module Build
|
|
class Failed < Status::Extended
|
|
REASONS = {
|
|
unknown_failure: 'unknown failure',
|
|
script_failure: 'script failure',
|
|
api_failure: 'API failure',
|
|
stuck_or_timeout_failure: 'stuck or timeout failure',
|
|
runner_system_failure: 'runner system failure',
|
|
missing_dependency_failure: 'missing dependency failure',
|
|
runner_unsupported: 'unsupported runner',
|
|
stale_schedule: 'stale schedule',
|
|
job_execution_timeout: 'job execution timeout',
|
|
archived_failure: 'archived failure',
|
|
unmet_prerequisites: 'unmet prerequisites'
|
|
}.freeze
|
|
|
|
private_constant :REASONS
|
|
|
|
def status_tooltip
|
|
base_message
|
|
end
|
|
|
|
def badge_tooltip
|
|
base_message
|
|
end
|
|
|
|
def self.matches?(build, user)
|
|
build.failed?
|
|
end
|
|
|
|
def self.reasons
|
|
REASONS
|
|
end
|
|
|
|
private
|
|
|
|
def base_message
|
|
"#{s_('CiStatusLabel|failed')} #{description}"
|
|
end
|
|
|
|
def description
|
|
"- (#{failure_reason_message})"
|
|
end
|
|
|
|
def failure_reason_message
|
|
self.class.reasons.fetch(subject.failure_reason.to_sym)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|