Commit ecb54cdd authored by Filip Krakowski's avatar Filip Krakowski Committed by Shinya Maeda

Add all sources as special keywords for only and except

parent 8db63b26
...@@ -393,7 +393,8 @@ There are a few rules that apply to the usage of refs policy: ...@@ -393,7 +393,8 @@ There are a few rules that apply to the usage of refs policy:
* `only` and `except` are inclusive. If both `only` and `except` are defined * `only` and `except` are inclusive. If both `only` and `except` are defined
in a job specification, the ref is filtered by `only` and `except`. in a job specification, the ref is filtered by `only` and `except`.
* `only` and `except` allow the use of regular expressions. * `only` and `except` allow the use of regular expressions.
* `only` and `except` allow the use of special keywords: `branches`, `tags`, `triggers` and `schedules`. * `only` and `except` allow the use of special keywords:
`api`, `branches`, `external`, `tags`, `pushes`, `schedules`, `triggers`, and `web`
* `only` and `except` allow to specify a repository path to filter jobs for * `only` and `except` allow to specify a repository path to filter jobs for
forks. forks.
......
...@@ -207,17 +207,15 @@ module Ci ...@@ -207,17 +207,15 @@ module Ci
def matching?(patterns, ref, tag, source) def matching?(patterns, ref, tag, source)
patterns.any? do |pattern| patterns.any? do |pattern|
match_ref?(pattern, ref, tag, source) match_ref?(pattern, ref, tag) || match_source?(pattern, source)
end end
end end
def match_ref?(pattern, ref, tag, source) def match_ref?(pattern, ref, tag)
pattern, path = pattern.split('@', 2) pattern, path = pattern.split('@', 2)
return false if path && path != self.path return false if path && path != self.path
return true if tag && pattern == 'tags' return true if tag && pattern == 'tags'
return true if !tag && pattern == 'branches' return true if !tag && pattern == 'branches'
return true if source == 'trigger' && pattern == 'triggers'
return true if source == 'schedule' && pattern == 'schedules'
if pattern.first == "/" && pattern.last == "/" if pattern.first == "/" && pattern.last == "/"
Regexp.new(pattern[1...-1]) =~ ref Regexp.new(pattern[1...-1]) =~ ref
...@@ -225,5 +223,14 @@ module Ci ...@@ -225,5 +223,14 @@ module Ci
pattern == ref pattern == ref
end end
end end
def match_source?(pattern, source)
return source_to_pattern(source) == pattern
end
def source_to_pattern(source)
return source if ['api', 'external', 'web'].include? source
return source.pluralize
end
end end
end end
...@@ -219,48 +219,44 @@ module Ci ...@@ -219,48 +219,44 @@ module Ci
expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(0) expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(0)
end end
it "returns builds if only has a triggers keyword specified and a trigger is provided" do it "returns builds if only has special keywords specified and source matches" do
config = YAML.dump({ possibilities = [{keyword: 'pushes', source: 'push'},
before_script: ["pwd"], {keyword: 'web', source: 'web'},
rspec: { script: "rspec", type: type, only: ["triggers"] } {keyword: 'triggers', source: 'trigger'},
}) {keyword: 'schedules', source: 'schedule'},
{keyword: 'api', source: 'api'},
config_processor = GitlabCiYamlProcessor.new(config, path) {keyword: 'external', source: 'external'}]
expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, 'trigger').size).to eq(1) possibilities.each do |possibility|
end config = YAML.dump({
before_script: ["pwd"],
it "returns builds if only has a schedules keyword specified and a schedule is provided" do rspec: { script: "rspec", type: type, only: [possibility[:keyword]] }
config = YAML.dump({ })
before_script: ["pwd"],
rspec: { script: "rspec", type: type, only: ["schedules"] } config_processor = GitlabCiYamlProcessor.new(config, path)
})
expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, possibility[:source]).size).to eq(1)
config_processor = GitlabCiYamlProcessor.new(config, path) end
expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, 'schedule').size).to eq(1)
end end
it "does not return builds if only has a triggers keyword specified and no trigger is provided" do it "does not return builds if only has special keywords specified and source doesn't match" do
config = YAML.dump({ possibilities = [{keyword: 'pushes', source: 'web'},
before_script: ["pwd"], {keyword: 'web', source: 'push'},
rspec: { script: "rspec", type: type, only: ["triggers"] } {keyword: 'triggers', source: 'schedule'},
}) {keyword: 'schedules', source: 'external'},
{keyword: 'api', source: 'trigger'},
config_processor = GitlabCiYamlProcessor.new(config, path) {keyword: 'external', source: 'api'}]
expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(0)
end
it "does not return builds if only has a schedules keyword specified and no schedule is provided" do possibilities.each do |possibility|
config = YAML.dump({ config = YAML.dump({
before_script: ["pwd"], before_script: ["pwd"],
rspec: { script: "rspec", type: type, only: ["schedules"] } rspec: { script: "rspec", type: type, only: [possibility[:keyword]] }
}) })
config_processor = GitlabCiYamlProcessor.new(config, path) config_processor = GitlabCiYamlProcessor.new(config, path)
expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(0) expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, possibility[:source]).size).to eq(0)
end
end end
it "returns builds if only has current repository path" do it "returns builds if only has current repository path" do
...@@ -397,48 +393,44 @@ module Ci ...@@ -397,48 +393,44 @@ module Ci
expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(1) expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(1)
end end
it "does not return builds if except has a triggers keyword specified and a trigger is provided" do it "does not return builds if except has special keywords specified and source matches" do
config = YAML.dump({ possibilities = [{keyword: 'pushes', source: 'push'},
before_script: ["pwd"], {keyword: 'web', source: 'web'},
rspec: { script: "rspec", type: type, except: ["triggers"] } {keyword: 'triggers', source: 'trigger'},
}) {keyword: 'schedules', source: 'schedule'},
{keyword: 'api', source: 'api'},
config_processor = GitlabCiYamlProcessor.new(config, path) {keyword: 'external', source: 'external'}]
expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, 'trigger').size).to eq(0)
end
it "does not return builds if except has a schedules keyword specified and a schedule is provided" do possibilities.each do |possibility|
config = YAML.dump({ config = YAML.dump({
before_script: ["pwd"], before_script: ["pwd"],
rspec: { script: "rspec", type: type, except: ["schedules"] } rspec: { script: "rspec", type: type, except: [possibility[:keyword]] }
}) })
config_processor = GitlabCiYamlProcessor.new(config, path) config_processor = GitlabCiYamlProcessor.new(config, path)
expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, 'schedule').size).to eq(0) expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, possibility[:source]).size).to eq(0)
end
end end
it "returns builds if except has a triggers keyword specified and no trigger is provided" do it "returns builds if except has special keywords specified and source doesn't match" do
config = YAML.dump({ possibilities = [{keyword: 'pushes', source: 'web'},
before_script: ["pwd"], {keyword: 'web', source: 'push'},
rspec: { script: "rspec", type: type, except: ["triggers"] } {keyword: 'triggers', source: 'schedule'},
}) {keyword: 'schedules', source: 'external'},
{keyword: 'api', source: 'trigger'},
{keyword: 'external', source: 'api'}]
config_processor = GitlabCiYamlProcessor.new(config, path) possibilities.each do |possibility|
config = YAML.dump({
before_script: ["pwd"],
rspec: { script: "rspec", type: type, only: [possibility[:keyword]] }
})
expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(1) config_processor = GitlabCiYamlProcessor.new(config, path)
end
it "returns builds if except has a schedules keyword specified and no schedule is provided" do expect(config_processor.builds_for_stage_and_ref(type, "deploy", false, possibility[:source]).size).to eq(1)
config = YAML.dump({ end
before_script: ["pwd"],
rspec: { script: "rspec", type: type, except: ["schedules"] }
})
config_processor = GitlabCiYamlProcessor.new(config, path)
expect(config_processor.builds_for_stage_and_ref(type, "deploy").size).to eq(1)
end end
it "does not return builds if except has current repository path" do it "does not return builds if except has current repository path" do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment