Skip to content
Snippets Groups Projects
Commit db09d105 authored by Grzegorz Bizon's avatar Grzegorz Bizon
Browse files

Add specs for build retry service

parent 9202b1f4
No related branches found
No related tags found
No related merge requests found
module Ci
class RetryBuildService
include Gitlab::Allowable
def initialize(build, user)
@build = build
@user = user
Loading
Loading
@@ -7,6 +9,10 @@ module Ci
end
 
def retry!
unless can?(@user, :update_build, @build)
raise Gitlab::Access::AccessDeniedError
end
clone_build.tap do |new_build|
new_build.enqueue!
 
Loading
Loading
require 'spec_helper'
describe Ci::RetryBuildService, :services do
let(:user) { create(:user) }
let(:project) { create(:empty_project) }
let(:pipeline) { create(:ci_pipeline, project: project) }
let(:build) { create(:ci_build, pipeline: pipeline) }
let(:service) do
described_class.new(build, user)
end
describe '#retry!' do
let(:new_build) { service.retry! }
context 'when user has ability to retry build' do
before do
project.team << [user, :developer]
end
it 'creates a new build that represents the old one' do
expect(new_build.name).to eq build.name
end
it 'enqueues the new build' do
expect(new_build).to be_pending
end
it 'resolves todos for old build that failed' do
expect(MergeRequests::AddTodoWhenBuildFailsService)
.to receive_message_chain(:new, :close)
service.retry!
end
context 'when there are subsequent builds that are skipped' do
let!(:subsequent_build) do
create(:ci_build, :skipped, stage_idx: 1, pipeline: pipeline)
end
it 'resumes pipeline processing in subsequent stages' do
service.retry!
expect(subsequent_build.reload).to be_created
end
end
end
context 'when user does not have ability to retry build' do
it 'raises an error' do
expect { service.retry! }
.to raise_error Gitlab::Access::AccessDeniedError
end
end
end
end
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment