summaryrefslogtreecommitdiff
path: root/spec/models
diff options
context:
space:
mode:
authorMatija Čupić <matteeyah@gmail.com>2018-10-27 18:04:09 +0200
committerMatija Čupić <matteeyah@gmail.com>2018-10-27 18:04:09 +0200
commitc2d49565cf787c592c4f8bd9f24843babd2a6c9a (patch)
tree713f54d7e80e8ae94e0c3e4b3faca81da1bc06ab /spec/models
parent72430483ded51e9a7d01ef70c3dce3dda174fac1 (diff)
downloadgitlab-ce-c2d49565cf787c592c4f8bd9f24843babd2a6c9a.tar.gz
Add build specs
Diffstat (limited to 'spec/models')
-rw-r--r--spec/models/ci/build_spec.rb48
1 files changed, 48 insertions, 0 deletions
diff --git a/spec/models/ci/build_spec.rb b/spec/models/ci/build_spec.rb
index a046541031e..41c3c37a7f2 100644
--- a/spec/models/ci/build_spec.rb
+++ b/spec/models/ci/build_spec.rb
@@ -1880,6 +1880,7 @@ describe Ci::Build do
{ key: 'CI_COMMIT_BEFORE_SHA', value: build.before_sha, public: true },
{ key: 'CI_COMMIT_REF_NAME', value: build.ref, public: true },
{ key: 'CI_COMMIT_REF_SLUG', value: build.ref_slug, public: true },
+ { key: 'CI_NODE_TOTAL', value: '1', public: true },
{ key: 'CI_BUILD_REF', value: build.sha, public: true },
{ key: 'CI_BUILD_BEFORE_SHA', value: build.before_sha, public: true },
{ key: 'CI_BUILD_REF_NAME', value: build.ref, public: true },
@@ -2341,6 +2342,28 @@ describe Ci::Build do
end
end
+ context 'when build is parallelized' do
+ let(:total) { 5 }
+ let(:index) { 3 }
+
+ before do
+ build.options[:parallel] = total
+ build.name = "#{build.name} #{index}/#{total}"
+ end
+
+ it 'includes CI_NODE_INDEX' do
+ is_expected.to include(
+ { key: 'CI_NODE_INDEX', value: index.to_s, public: true }
+ )
+ end
+
+ it 'includes correct CI_NODE_TOTAL' do
+ is_expected.to include(
+ { key: 'CI_NODE_TOTAL', value: total.to_s, public: true }
+ )
+ end
+ end
+
describe 'variables ordering' do
context 'when variables hierarchy is stubbed' do
let(:build_pre_var) { { key: 'build', value: 'value', public: true } }
@@ -2447,6 +2470,31 @@ describe Ci::Build do
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
describe '#scoped_variables' do