ac77bb9376
- Added Gitlab::Ci::Config::Entry::Rules and Gitlab::Ci::Config::Entry::Rules:Rule to handle lists of Rule objects to be evalauted for job inclusion - Added `if:` and `changes:` as available Rules::Rule::Clause classes - Added Rules handling logic to Seed::Build#included? with extra specs - Use DisallowedKeysValidator to mutually exclude rules: from only:/except: on job config
37 lines
916 B
Ruby
37 lines
916 B
Ruby
# frozen_string_literal: true
|
|
|
|
module Gitlab
|
|
module Ci
|
|
module Build
|
|
class Rules
|
|
include ::Gitlab::Utils::StrongMemoize
|
|
|
|
Result = Struct.new(:when, :start_in)
|
|
|
|
def initialize(rule_hashes, default_when = 'on_success')
|
|
@rule_list = Rule.fabricate_list(rule_hashes)
|
|
@default_when = default_when
|
|
end
|
|
|
|
def evaluate(pipeline, build)
|
|
if @rule_list.nil?
|
|
Result.new(@default_when)
|
|
elsif matched_rule = match_rule(pipeline, build)
|
|
Result.new(
|
|
matched_rule.attributes[:when] || @default_when,
|
|
matched_rule.attributes[:start_in]
|
|
)
|
|
else
|
|
Result.new('never')
|
|
end
|
|
end
|
|
|
|
private
|
|
|
|
def match_rule(pipeline, build)
|
|
@rule_list.find { |rule| rule.matches?(pipeline, build) }
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|