Commit 73e17446 authored by Matija Čupić's avatar Matija Čupić

Move parallelized node index to job options

parent 77715e47
...@@ -801,16 +801,12 @@ module Ci ...@@ -801,16 +801,12 @@ module Ci
variables.append(key: "CI_COMMIT_TAG", value: ref) if tag? variables.append(key: "CI_COMMIT_TAG", value: ref) if tag?
variables.append(key: "CI_PIPELINE_TRIGGERED", value: 'true') if trigger_request variables.append(key: "CI_PIPELINE_TRIGGERED", value: 'true') if trigger_request
variables.append(key: "CI_JOB_MANUAL", value: 'true') if action? variables.append(key: "CI_JOB_MANUAL", value: 'true') if action?
variables.append(key: "CI_NODE_INDEX", value: node_index.to_s) if self.options&.include?(:parallel) variables.append(key: "CI_NODE_INDEX", value: self.options[:instance].to_s) if self.options&.include?(:instance)
variables.append(key: "CI_NODE_TOTAL", value: (self.options&.dig(:parallel) || 1).to_s) variables.append(key: "CI_NODE_TOTAL", value: (self.options&.dig(:parallel) || 1).to_s)
variables.concat(legacy_variables) variables.concat(legacy_variables)
end end
end end
def node_index
name.match(%r{(\d+)/\d+$}).captures[0]
end
def gitlab_version_info def gitlab_version_info
@gitlab_version_info ||= Gitlab::VersionInfo.parse(Gitlab::VERSION) @gitlab_version_info ||= Gitlab::VersionInfo.parse(Gitlab::VERSION)
end end
......
...@@ -10,8 +10,8 @@ module Gitlab ...@@ -10,8 +10,8 @@ module Gitlab
if config[:parallel] if config[:parallel]
total = config[:parallel] total = config[:parallel]
names = parallelize_job_names(name, total) names = parallelize_job_names(name, total)
parallelized_jobs[name] = names parallelized_jobs[name] = names.map(&:first)
Hash[names.collect { |job_name| [job_name.to_sym, config.merge(name: job_name)] }] Hash[names.collect { |job_name, index| [job_name.to_sym, config.merge(name: job_name, instance: index)] }]
else else
{ name => config } { name => config }
end end
...@@ -39,7 +39,7 @@ module Gitlab ...@@ -39,7 +39,7 @@ module Gitlab
jobs = [] jobs = []
total.times do |idx| total.times do |idx|
jobs << "#{name} #{idx + 1}/#{total}" jobs << ["#{name} #{idx + 1}/#{total}", idx + 1]
end end
jobs jobs
......
...@@ -51,6 +51,7 @@ module Gitlab ...@@ -51,6 +51,7 @@ module Gitlab
environment: job[:environment], environment: job[:environment],
retry: job[:retry], retry: job[:retry],
parallel: job[:parallel], parallel: job[:parallel],
instance: job[:instance],
start_in: job[:start_in] start_in: job[:start_in]
}.compact } }.compact }
end end
......
...@@ -2,7 +2,7 @@ require 'fast_spec_helper' ...@@ -2,7 +2,7 @@ require 'fast_spec_helper'
describe Gitlab::Ci::Config::Normalizer do describe Gitlab::Ci::Config::Normalizer do
let(:job_name) { :rspec } let(:job_name) { :rspec }
let(:job_config) { { script: 'rspec', parallel: 5 } } let(:job_config) { { script: 'rspec', parallel: 5, name: 'rspec' } }
let(:config) { { job_name => job_config } } let(:config) { { job_name => job_config } }
describe '.normalize_jobs' do describe '.normalize_jobs' do
...@@ -13,14 +13,18 @@ describe Gitlab::Ci::Config::Normalizer do ...@@ -13,14 +13,18 @@ describe Gitlab::Ci::Config::Normalizer do
end end
it 'has parallelized jobs' do it 'has parallelized jobs' do
job_names = described_class.send(:parallelize_job_names, job_name, 5).map(&:to_sym) job_names = described_class.send(:parallelize_job_names, job_name, 5).map { |job_name, index| job_name.to_sym }
is_expected.to include(*job_names) is_expected.to include(*job_names)
end end
it 'sets job instance in options' do
expect(subject.values).to all(include(:instance))
end
it 'parallelizes jobs with original config' do it 'parallelizes jobs with original config' do
original_config = config[job_name].except(:name) original_config = config[job_name].except(:name)
configs = subject.values.map { |config| config.except(:name) } configs = subject.values.map { |config| config.except(:name, :instance) }
expect(configs).to all(eq(original_config)) expect(configs).to all(eq(original_config))
end end
...@@ -30,7 +34,7 @@ describe Gitlab::Ci::Config::Normalizer do ...@@ -30,7 +34,7 @@ describe Gitlab::Ci::Config::Normalizer do
subject { described_class.send(:parallelize_job_names, job_name, 5) } subject { described_class.send(:parallelize_job_names, job_name, 5) }
it 'returns parallelized names' do it 'returns parallelized names' do
is_expected.to all(match(%r{#{job_name} \d+/\d+})) expect(subject.map(&:first)).to all(match(%r{#{job_name} \d+/\d+}))
end end
end end
end end
...@@ -657,9 +657,17 @@ module Gitlab ...@@ -657,9 +657,17 @@ module Gitlab
it 'returns parallelized jobs' do it 'returns parallelized jobs' do
config_processor = Gitlab::Ci::YamlProcessor.new(config) config_processor = Gitlab::Ci::YamlProcessor.new(config)
builds = config_processor.stage_builds_attributes('test') builds = config_processor.stage_builds_attributes('test')
build_options = builds.map { |build| build[:options] }
expect(builds.size).to eq(5) expect(builds.size).to eq(5)
expect(builds.map { |build| build[:options] }).to all(include(parallel: parallel)) expect(build_options).to all(include(:instance, parallel: parallel))
end
it 'does not have the original job' do
config_processor = Gitlab::Ci::YamlProcessor.new(config)
builds = config_processor.stage_builds_attributes('test')
expect(builds).not_to include(:rspec)
end end
end end
end end
......
...@@ -2348,6 +2348,7 @@ describe Ci::Build do ...@@ -2348,6 +2348,7 @@ describe Ci::Build do
before do before do
build.options[:parallel] = total build.options[:parallel] = total
build.options[:instance] = index
build.name = "#{build.name} #{index}/#{total}" build.name = "#{build.name} #{index}/#{total}"
end end
...@@ -2470,31 +2471,6 @@ describe Ci::Build do ...@@ -2470,31 +2471,6 @@ describe Ci::Build do
end end
end end
end end
describe '#node_index' do
subject { build.send(:node_index) }
let(:index) { 4 }
context 'when build has only one index' do
before do
build.name = "#{build.name} #{index}/5"
end
it 'returns the index' do
expect(subject).to eq(index.to_s)
end
end
context 'when build has more than one one index' do
before do
build.name = "test_build 1/3 #{index}/5"
end
it 'returns the last index' do
expect(subject).to eq(index.to_s)
end
end
end
end end
describe '#scoped_variables' do describe '#scoped_variables' 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