Select Git revision
Forked from
GitLab.org / GitLab FOSS
Source project has a limited visibility.
-
Kamil Trzcinski authored
This change simplifies a Pipeline processing by introducing a special new status: created. This status is used for all builds that are created for a pipeline. We are then processing next stages and queueing some of the builds (created -> pending) or skipping them (created -> skipped). This makes it possible to simplify and solve a few ordering problems with how previously builds were scheduled. This also allows us to visualise a full pipeline (with created builds). This also removes an after_touch used for updating a pipeline state parameters. Right now in various places we explicitly call a reload_status! on pipeline to force it to be updated and saved.
Kamil Trzcinski authoredThis change simplifies a Pipeline processing by introducing a special new status: created. This status is used for all builds that are created for a pipeline. We are then processing next stages and queueing some of the builds (created -> pending) or skipping them (created -> skipped). This makes it possible to simplify and solve a few ordering problems with how previously builds were scheduled. This also allows us to visualise a full pipeline (with created builds). This also removes an after_touch used for updating a pipeline state parameters. Right now in various places we explicitly call a reload_status! on pipeline to force it to be updated and saved.
entry.rb NaN GiB
module Gitlab
module Ci
class Config
module Node
class Entry
class InvalidError < StandardError; end
attr_accessor :description
def initialize(value, root = nil, parent = nil)
@value = value
@root = root
@parent = parent
@nodes = {}
@errors = []
end
def process!
return if leaf? || invalid?
compose!
nodes.each(&:process!)
nodes.each(&:validate!)
end
def compose!
keys.each do |key, entry|
add_node(key, entry)
end
end
def nodes
@nodes.values
end
def valid?
errors.none?
end
def invalid?
!valid?
end
def leaf?
keys.none?
end
def has_config?
@value.is_a?(Hash)
end
def keys
{}
end
def errors
@errors + nodes.map(&:errors).flatten
end
def method_missing(name, *args)
super unless keys.has_key?(name)
raise InvalidError unless valid?
@nodes[name].try(:value)
end
def add_node(key, entry)
raise NotImplementedError
end
def value
raise NotImplementedError
end
def validate!
raise NotImplementedError
end
end
end
end
end
end