2019-05-18 00:54:41 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe CreatePipelineWorker do
|
2018-03-17 18:26:18 +05:30
|
|
|
describe '#perform' do
|
|
|
|
let(:worker) { described_class.new }
|
|
|
|
|
|
|
|
context 'when a project not found' do
|
|
|
|
it 'does not call the Service' do
|
|
|
|
expect(Ci::CreatePipelineService).not_to receive(:new)
|
|
|
|
expect { worker.perform(99, create(:user).id, 'master', :web) }.to raise_error(ActiveRecord::RecordNotFound)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a user not found' do
|
|
|
|
let(:project) { create(:project) }
|
|
|
|
|
|
|
|
it 'does not call the Service' do
|
|
|
|
expect(Ci::CreatePipelineService).not_to receive(:new)
|
|
|
|
expect { worker.perform(project.id, 99, project.default_branch, :web) }.to raise_error(ActiveRecord::RecordNotFound)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when everything is ok' do
|
|
|
|
let(:project) { create(:project) }
|
|
|
|
let(:user) { create(:user) }
|
|
|
|
let(:create_pipeline_service) { instance_double(Ci::CreatePipelineService) }
|
|
|
|
|
|
|
|
it 'calls the Service' do
|
|
|
|
expect(Ci::CreatePipelineService).to receive(:new).with(project, user, ref: project.default_branch).and_return(create_pipeline_service)
|
|
|
|
expect(create_pipeline_service).to receive(:execute).with(:web, any_args)
|
|
|
|
|
|
|
|
worker.perform(project.id, user.id, project.default_branch, :web)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|