debian-mirror-gitlab/spec/services/discussions/resolve_service_spec.rb

112 lines
4 KiB
Ruby
Raw Normal View History

2019-07-31 22:56:46 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe Discussions::ResolveService do
2017-08-17 22:00:37 +05:30
describe '#execute' do
2020-06-23 00:09:42 +05:30
let_it_be(:project) { create(:project, :repository) }
let_it_be(:user) { create(:user, developer_projects: [project]) }
let_it_be(:merge_request) { create(:merge_request, :merge_when_pipeline_succeeds, source_project: project) }
let(:discussion) { create(:diff_note_on_merge_request, noteable: merge_request, project: project).to_discussion }
let(:service) { described_class.new(project, user, one_or_more_discussions: discussion) }
2017-08-17 22:00:37 +05:30
it "doesn't resolve discussions the user can't resolve" do
expect(discussion).to receive(:can_resolve?).with(user).and_return(false)
2020-06-23 00:09:42 +05:30
service.execute
2017-08-17 22:00:37 +05:30
2020-06-23 00:09:42 +05:30
expect(discussion).not_to be_resolved
2017-08-17 22:00:37 +05:30
end
it 'resolves the discussion' do
2020-06-23 00:09:42 +05:30
service.execute
2017-08-17 22:00:37 +05:30
2020-06-23 00:09:42 +05:30
expect(discussion).to be_resolved
2017-08-17 22:00:37 +05:30
end
it 'executes the notification service' do
2020-01-01 13:55:28 +05:30
expect_next_instance_of(MergeRequests::ResolvedDiscussionNotificationService) do |instance|
expect(instance).to receive(:execute).with(discussion.noteable)
end
2017-08-17 22:00:37 +05:30
2020-06-23 00:09:42 +05:30
service.execute
end
it 'schedules an auto-merge' do
expect(AutoMergeProcessWorker).to receive(:perform_async).with(discussion.noteable.id)
service.execute
end
context 'with a project that requires all discussion to be resolved' do
before do
2021-01-29 00:20:46 +05:30
project.update!(only_allow_merge_if_all_discussions_are_resolved: true)
2020-06-23 00:09:42 +05:30
end
after do
2021-01-29 00:20:46 +05:30
project.update!(only_allow_merge_if_all_discussions_are_resolved: false)
2020-06-23 00:09:42 +05:30
end
let_it_be(:other_discussion) { create(:diff_note_on_merge_request, noteable: merge_request, project: project).to_discussion }
it 'does not schedule an auto-merge' do
expect(AutoMergeProcessWorker).not_to receive(:perform_async)
service.execute
end
it 'schedules an auto-merge' do
expect(AutoMergeProcessWorker).to receive(:perform_async)
described_class.new(project, user, one_or_more_discussions: [discussion, other_discussion]).execute
end
2017-08-17 22:00:37 +05:30
end
it 'adds a system note to the discussion' do
issue = create(:issue, project: project)
expect(SystemNoteService).to receive(:discussion_continued_in_issue).with(discussion, project, user, issue)
2020-06-23 00:09:42 +05:30
service = described_class.new(project, user, one_or_more_discussions: discussion, follow_up_issue: issue)
service.execute
2017-08-17 22:00:37 +05:30
end
it 'can resolve multiple discussions at once' do
2020-06-23 00:09:42 +05:30
other_discussion = create(:diff_note_on_merge_request, noteable: merge_request, project: project).to_discussion
service = described_class.new(project, user, one_or_more_discussions: [discussion, other_discussion])
service.execute
2017-08-17 22:00:37 +05:30
2020-06-23 00:09:42 +05:30
expect([discussion, other_discussion]).to all(be_resolved)
end
it 'raises an argument error if discussions do not belong to the same noteable' do
other_merge_request = create(:merge_request)
other_discussion = create(:diff_note_on_merge_request,
noteable: other_merge_request,
project: other_merge_request.source_project).to_discussion
expect do
described_class.new(project, user, one_or_more_discussions: [discussion, other_discussion])
end.to raise_error(
ArgumentError,
'Discussions must be all for the same noteable'
)
end
2017-08-17 22:00:37 +05:30
2020-06-23 00:09:42 +05:30
context 'when discussion is not for a merge request' do
let_it_be(:design) { create(:design, :with_file, issue: create(:issue, project: project)) }
let(:discussion) { create(:diff_note_on_design, noteable: design, project: project).to_discussion }
it 'does not execute the notification service' do
expect(MergeRequests::ResolvedDiscussionNotificationService).not_to receive(:new)
service.execute
end
it 'does not schedule an auto-merge' do
expect(AutoMergeProcessWorker).not_to receive(:perform_async)
service.execute
end
2017-08-17 22:00:37 +05:30
end
end
end