97 lines
2.8 KiB
Ruby
97 lines
2.8 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe MergeRequests::AfterCreateService do
|
|
let_it_be(:merge_request) { create(:merge_request) }
|
|
|
|
subject(:after_create_service) do
|
|
described_class.new(merge_request.target_project, merge_request.author)
|
|
end
|
|
|
|
describe '#execute' do
|
|
let(:event_service) { instance_double('EventCreateService', open_mr: true) }
|
|
let(:notification_service) { instance_double('NotificationService', new_merge_request: true) }
|
|
|
|
before do
|
|
allow(after_create_service).to receive(:event_service).and_return(event_service)
|
|
allow(after_create_service).to receive(:notification_service).and_return(notification_service)
|
|
end
|
|
|
|
subject(:execute_service) { after_create_service.execute(merge_request) }
|
|
|
|
it 'creates a merge request open event' do
|
|
expect(event_service)
|
|
.to receive(:open_mr).with(merge_request, merge_request.author)
|
|
|
|
execute_service
|
|
end
|
|
|
|
it 'calls the merge request activity counter' do
|
|
expect(Gitlab::UsageDataCounters::MergeRequestActivityUniqueCounter)
|
|
.to receive(:track_create_mr_action)
|
|
.with(user: merge_request.author)
|
|
|
|
expect(Gitlab::UsageDataCounters::MergeRequestActivityUniqueCounter)
|
|
.to receive(:track_mr_including_ci_config)
|
|
.with(user: merge_request.author, merge_request: merge_request)
|
|
|
|
execute_service
|
|
end
|
|
|
|
it 'creates a new merge request notification' do
|
|
expect(notification_service)
|
|
.to receive(:new_merge_request).with(merge_request, merge_request.author)
|
|
|
|
execute_service
|
|
end
|
|
|
|
it 'writes diffs to the cache' do
|
|
expect(merge_request)
|
|
.to receive_message_chain(:diffs, :write_cache)
|
|
|
|
execute_service
|
|
end
|
|
|
|
it 'creates cross references' do
|
|
expect(merge_request)
|
|
.to receive(:create_cross_references!).with(merge_request.author)
|
|
|
|
execute_service
|
|
end
|
|
|
|
it 'creates a pipeline and updates the HEAD pipeline' do
|
|
expect(after_create_service)
|
|
.to receive(:create_pipeline_for).with(merge_request, merge_request.author)
|
|
expect(merge_request).to receive(:update_head_pipeline)
|
|
|
|
execute_service
|
|
end
|
|
|
|
it_behaves_like 'records an onboarding progress action', :merge_request_created do
|
|
let(:namespace) { merge_request.target_project.namespace }
|
|
end
|
|
|
|
context 'when merge request is in unchecked state' do
|
|
before do
|
|
merge_request.mark_as_unchecked!
|
|
execute_service
|
|
end
|
|
|
|
it 'does not change its state' do
|
|
expect(merge_request.reload).to be_unchecked
|
|
end
|
|
end
|
|
|
|
context 'when merge request is in preparing state' do
|
|
before do
|
|
merge_request.mark_as_preparing!
|
|
execute_service
|
|
end
|
|
|
|
it 'marks the merge request as unchecked' do
|
|
expect(merge_request.reload).to be_unchecked
|
|
end
|
|
end
|
|
end
|
|
end
|