summaryrefslogtreecommitdiff
path: root/spec/models/ci
diff options
context:
space:
mode:
authorMarkus Doits <markus.doits@stellenticket.de>2018-09-15 14:31:36 +0200
committerMarkus Doits <markus.doits@stellenticket.de>2018-11-07 13:00:40 +0100
commit39204d8c6184328b21e4057aaa78d698abd56e29 (patch)
tree439561ceb5aa539946ac48f796578ce3f03e103b /spec/models/ci
parent007db85dd4e4c92e060160427429c4fb2ad5cb32 (diff)
downloadgitlab-ce-39204d8c6184328b21e4057aaa78d698abd56e29.tar.gz
refactor retry logic to define any reason and more than one reason to retry
Diffstat (limited to 'spec/models/ci')
-rw-r--r--spec/models/ci/build_spec.rb124
1 files changed, 23 insertions, 101 deletions
diff --git a/spec/models/ci/build_spec.rb b/spec/models/ci/build_spec.rb
index 3085cf7b271..4f113d2e653 100644
--- a/spec/models/ci/build_spec.rb
+++ b/spec/models/ci/build_spec.rb
@@ -1514,11 +1514,19 @@ describe Ci::Build do
end
describe '#retry_when' do
- context 'when value is defined' do
- subject { create(:ci_build, options: { retry: { when: :something } }) }
+ context 'when value is defined without an array' do
+ subject { create(:ci_build, options: { retry: { when: 'something' } }) }
+
+ it 'returns the configured value inside an array' do
+ expect(subject.retry_when).to eq ['something']
+ end
+ end
+
+ context 'when value is defined without as an array' do
+ subject { create(:ci_build, options: { retry: { when: %w[something more] } }) }
it 'returns the configured value' do
- expect(subject.retry_when).to eq :something
+ expect(subject.retry_when).to eq %w[something more]
end
end
@@ -1526,7 +1534,7 @@ describe Ci::Build do
subject { create(:ci_build) }
it 'returns `always`' do
- expect(subject.retry_when).to eq :always
+ expect(subject.retry_when).to eq ['always']
end
end
@@ -1534,7 +1542,7 @@ describe Ci::Build do
subject { create(:ci_build, options: { retry: 1 }) }
it 'returns `always`' do
- expect(subject.retry_when).to eq :always
+ expect(subject.retry_when).to eq ['always']
end
end
end
@@ -1579,111 +1587,25 @@ describe Ci::Build do
end
end
- context 'and failure was a system runner failure' do
- before do
- expect(subject).to receive(:failure_reason).at_least(:once).and_return('runner_system_failure')
- end
-
- context 'and retry when is always' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('always')
- end
-
- it 'returns true' do
- expect(subject.retry_failure?).to eq true
- end
- end
-
- context 'and retry when is system failure' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('system failure')
- end
-
- it 'returns true' do
- expect(subject.retry_failure?).to eq true
- end
- end
-
- context 'and retry when is script failure' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('script failure')
- end
-
- it 'returns false' do
- expect(subject.retry_failure?).to eq false
- end
- end
- end
-
- context 'and failure was a script failure' do
+ context 'and retry when includes the failure_reason' do
before do
- expect(subject).to receive(:failure_reason).at_least(:once).and_return('script_failure')
- end
-
- context 'and retry when is always' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('always')
- end
-
- it 'returns true' do
- expect(subject.retry_failure?).to eq true
- end
- end
-
- context 'and retry when is system failure' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('system failure')
- end
-
- it 'returns false' do
- expect(subject.retry_failure?).to eq false
- end
+ expect(subject).to receive(:failure_reason).at_least(:once).and_return('some_reason')
+ expect(subject).to receive(:retry_when).at_least(:once).and_return(['some_reason'])
end
- context 'and retry when is script failure' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('script failure')
- end
-
- it 'returns true' do
- expect(subject.retry_failure?).to eq true
- end
+ it 'returns true' do
+ expect(subject.retry_failure?).to eq true
end
end
- context 'and failure was some other failure' do
+ context 'and retry when does not include failure_reason' do
before do
- expect(subject).to receive(:failure_reason).at_least(:once).and_return('some other reason')
- end
-
- context 'and retry when is always' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('always')
- end
-
- it 'returns true' do
- expect(subject.retry_failure?).to eq true
- end
+ expect(subject).to receive(:failure_reason).at_least(:once).and_return('some_reason')
+ expect(subject).to receive(:retry_when).at_least(:once).and_return(['some', 'other failure'])
end
- context 'and retry when is system failure' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('system failure')
- end
-
- it 'returns false' do
- expect(subject.retry_failure?).to eq false
- end
- end
-
- context 'and retry when is script failure' do
- before do
- expect(subject).to receive(:retry_when).at_least(:once).and_return('script failure')
- end
-
- it 'returns false' do
- expect(subject.retry_failure?).to eq false
- end
+ it 'returns false' do
+ expect(subject.retry_failure?).to eq false
end
end
end