47 lines
1.2 KiB
Ruby
47 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Gitlab
|
|
module Ci
|
|
module Pipeline
|
|
module Chain
|
|
class Sequence
|
|
def initialize(pipeline, command, sequence)
|
|
@pipeline = pipeline
|
|
@command = command
|
|
@sequence = sequence
|
|
@start = current_monotonic_time
|
|
end
|
|
|
|
def build!
|
|
@sequence.each do |step_class|
|
|
step_start = current_monotonic_time
|
|
step = step_class.new(@pipeline, @command)
|
|
|
|
step.perform!
|
|
|
|
@command.observe_step_duration(
|
|
step_class,
|
|
current_monotonic_time - step_start
|
|
)
|
|
|
|
break if step.break?
|
|
end
|
|
|
|
@command.observe_creation_duration(current_monotonic_time - @start)
|
|
@command.observe_pipeline_size(@pipeline)
|
|
@command.observe_jobs_count_in_alive_pipelines
|
|
@command.observe_pipeline_includes_count(@pipeline)
|
|
|
|
@pipeline
|
|
end
|
|
|
|
private
|
|
|
|
def current_monotonic_time
|
|
::Gitlab::Metrics::System.monotonic_time
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|