debian-mirror-gitlab/lib/gitlab/ci/pipeline/chain/sequence.rb
2022-01-26 12:08:38 +05:30

46 lines
1.1 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
@pipeline
end
private
def current_monotonic_time
::Gitlab::Metrics::System.monotonic_time
end
end
end
end
end
end