summaryrefslogtreecommitdiff
path: root/lib/gitlab/ci
diff options
context:
space:
mode:
authorGrzegorz Bizon <grzesiek.bizon@gmail.com>2018-02-28 10:50:02 +0100
committerGrzegorz Bizon <grzesiek.bizon@gmail.com>2018-02-28 10:50:02 +0100
commitc52255884ea1a54d66c0e5e52a67c25ad1a62644 (patch)
tree56fcbfbd88b43189e3e1096f4bb1ff9dba3ec47f /lib/gitlab/ci
parent4f472d49b52452b0377fa0701dfe970f3e83bb85 (diff)
downloadgitlab-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.rb20
-rw-r--r--lib/gitlab/ci/pipeline/expression/statement.rb14
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