Commit 783bd2b7 authored by Thong Kuah's avatar Thong Kuah

Add specs to verify CI services run after commit

parent 0f030f83
...@@ -1856,15 +1856,31 @@ RSpec.describe User do ...@@ -1856,15 +1856,31 @@ RSpec.describe User do
end end
context 'when user has running CI pipelines' do context 'when user has running CI pipelines' do
let(:service) { double }
let(:pipelines) { build_list(:ci_pipeline, 3, :running) } let(:pipelines) { build_list(:ci_pipeline, 3, :running) }
it 'aborts all running pipelines and related jobs' do it 'drops all running pipelines and related jobs' do
drop_service = double
disable_service = double
expect(user).to receive(:pipelines).and_return(pipelines) expect(user).to receive(:pipelines).and_return(pipelines)
expect(Ci::DropPipelineService).to receive(:new).and_return(service) expect(Ci::DropPipelineService).to receive(:new).and_return(drop_service)
expect(service).to receive(:execute_async_for_all).with(pipelines, :user_blocked, user) expect(drop_service).to receive(:execute_async_for_all).with(pipelines, :user_blocked, user)
user.block expect(Ci::DisableUserPipelineSchedulesService).to receive(:new).and_return(disable_service)
expect(disable_service).to receive(:execute).with(user)
user.block!
end
it 'does not drop running pipelines if the transaction rolls back' do
expect(Ci::DropPipelineService).not_to receive(:new)
expect(Ci::DisableUserPipelineSchedulesService).not_to receive(:new)
User.transaction do
user.block
raise ActiveRecord::Rollback
end
end end
end end
......
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