diff options
author | Grzegorz Bizon <grzesiek.bizon@gmail.com> | 2018-02-28 10:50:02 +0100 |
---|---|---|
committer | Grzegorz Bizon <grzesiek.bizon@gmail.com> | 2018-02-28 10:50:02 +0100 |
commit | c52255884ea1a54d66c0e5e52a67c25ad1a62644 (patch) | |
tree | 56fcbfbd88b43189e3e1096f4bb1ff9dba3ec47f /lib/gitlab/ci | |
parent | 4f472d49b52452b0377fa0701dfe970f3e83bb85 (diff) | |
download | gitlab-ce-c52255884ea1a54d66c0e5e52a67c25ad1a62644.tar.gz |
Add support for only/except: variables CI/CD config
Diffstat (limited to 'lib/gitlab/ci')
-rw-r--r-- | lib/gitlab/ci/config/entry/policy.rb | 20 | ||||
-rw-r--r-- | lib/gitlab/ci/pipeline/expression/statement.rb | 14 |
2 files changed, 31 insertions, 3 deletions
diff --git a/lib/gitlab/ci/config/entry/policy.rb b/lib/gitlab/ci/config/entry/policy.rb index 0027e9ec8c5..b6d137a7e68 100644 --- a/lib/gitlab/ci/config/entry/policy.rb +++ b/lib/gitlab/ci/config/entry/policy.rb @@ -25,15 +25,31 @@ module Gitlab include Entry::Validatable include Entry::Attributable - attributes :refs, :kubernetes + attributes :refs, :kubernetes, :variables validations do validates :config, presence: true - validates :config, allowed_keys: %i[refs kubernetes] + validates :config, allowed_keys: %i[refs kubernetes variables] + validate :variables_expressions_syntax with_options allow_nil: true do validates :refs, array_of_strings_or_regexps: true validates :kubernetes, allowed_values: %w[active] + validates :variables, array_of_strings: true + end + + def variables_expressions_syntax + return unless variables.is_a?(Array) + + statements = variables.map do |statement| + ::Gitlab::Ci::Pipeline::Expression::Statement.new(statement) + end + + statements.each do |statement| + unless statement.valid? + errors.add(:variables, "Invalid expression #{statement.inspect}") + end + end end end end diff --git a/lib/gitlab/ci/pipeline/expression/statement.rb b/lib/gitlab/ci/pipeline/expression/statement.rb index 08e662eccf9..616a9fe204c 100644 --- a/lib/gitlab/ci/pipeline/expression/statement.rb +++ b/lib/gitlab/ci/pipeline/expression/statement.rb @@ -14,9 +14,11 @@ module Gitlab %w[variable] ].freeze - def initialize(statement, pipeline) + def initialize(statement, pipeline = nil) @lexer = Expression::Lexer.new(statement) + return if pipeline.nil? + @variables = pipeline.variables.map do |variable| [variable.key.to_sym, variable.value] end @@ -35,6 +37,16 @@ module Gitlab def evaluate parse_tree.evaluate(@variables.to_h) end + + def inspect + "syntax: #{@lexer.lexemes.join(' ')}" + end + + def valid? + parse_tree.is_a?(Lexeme::Base) + rescue StatementError + false + end end end end |