debian-mirror-gitlab/spec/services/merge_requests/update_assignees_service_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

133 lines
4.1 KiB
Ruby
Raw Normal View History

2021-04-29 21:17:54 +05:30
# frozen_string_literal: true
require 'spec_helper'
2023-05-27 22:25:52 +05:30
RSpec.describe MergeRequests::UpdateAssigneesService, feature_category: :code_review_workflow do
2021-04-29 21:17:54 +05:30
include AfterNextHelpers
let_it_be(:group) { create(:group, :public) }
let_it_be(:project) { create(:project, :private, :repository, group: group) }
let_it_be(:user) { create(:user) }
let_it_be(:user2) { create(:user) }
let_it_be(:user3) { create(:user) }
let_it_be_with_reload(:merge_request) do
2023-07-09 08:55:56 +05:30
create(
:merge_request,
:simple,
:unique_branches,
title: 'Old title',
description: "FYI #{user2.to_reference}",
assignee_ids: [user3.id],
source_project: project,
target_project: project,
author: create(:user)
)
2021-04-29 21:17:54 +05:30
end
before do
project.add_maintainer(user)
project.add_developer(user2)
project.add_developer(user3)
2021-09-04 01:27:46 +05:30
merge_request.errors.clear
2021-04-29 21:17:54 +05:30
end
2021-06-08 01:23:25 +05:30
let(:service) { described_class.new(project: project, current_user: user, params: opts) }
2021-04-29 21:17:54 +05:30
let(:opts) { { assignee_ids: [user2.id] } }
describe 'execute' do
def update_merge_request
service.execute(merge_request)
2021-09-04 01:27:46 +05:30
end
2022-11-25 23:54:43 +05:30
shared_examples 'it updates and enqueues the job' do
it 'correctly updates the MR and enqueues the job' do
expect_next(MergeRequests::HandleAssigneesChangeService, project: project, current_user: user) do |service|
expect(service)
.to receive(:async_execute).with(merge_request, [user3], execute_hooks: true)
end
expect { update_merge_request }
.to change { merge_request.reload.assignees }.from([user3]).to(new_users)
.and change(merge_request, :updated_at)
.and change(merge_request, :updated_by).to(user)
end
end
2021-09-04 01:27:46 +05:30
shared_examples 'removing all assignees' do
it 'removes all assignees' do
expect(update_merge_request).to have_attributes(assignees: be_empty, errors: be_none)
end
it 'enqueues the correct background work' do
expect_next(MergeRequests::HandleAssigneesChangeService, project: project, current_user: user) do |service|
expect(service)
.to receive(:async_execute)
.with(merge_request, [user3], execute_hooks: true)
end
update_merge_request
end
2021-04-29 21:17:54 +05:30
end
context 'when the parameters are valid' do
2021-06-08 01:23:25 +05:30
context 'when using sentinel values' do
2021-09-04 01:27:46 +05:30
context 'when using assignee_ids' do
let(:opts) { { assignee_ids: [0] } }
it_behaves_like 'removing all assignees'
end
2021-06-08 01:23:25 +05:30
2021-09-04 01:27:46 +05:30
context 'when using assignee_id' do
let(:opts) { { assignee_id: 0 } }
it_behaves_like 'removing all assignees'
2021-06-08 01:23:25 +05:30
end
end
2021-09-04 01:27:46 +05:30
context 'when the assignee_ids parameter is the empty list' do
2021-06-08 01:23:25 +05:30
let(:opts) { { assignee_ids: [] } }
2021-09-04 01:27:46 +05:30
it_behaves_like 'removing all assignees'
2021-06-08 01:23:25 +05:30
end
2022-11-25 23:54:43 +05:30
it_behaves_like 'it updates and enqueues the job' do
let(:new_users) { [user2] }
2021-04-29 21:17:54 +05:30
end
it 'does not update the assignees if they do not have access' do
opts[:assignee_ids] = [create(:user).id]
2021-09-04 01:27:46 +05:30
expect(update_merge_request).to have_attributes(
assignees: [user3],
errors: be_any
)
2021-04-29 21:17:54 +05:30
end
it 'is more efficient than using the full update-service' do
2021-06-08 01:23:25 +05:30
allow_next(MergeRequests::HandleAssigneesChangeService, project: project, current_user: user) do |service|
2021-04-29 21:17:54 +05:30
expect(service)
.to receive(:async_execute)
.with(merge_request, [user3], execute_hooks: true)
end
2023-07-09 08:55:56 +05:30
other_mr = create(
:merge_request,
:simple,
:unique_branches,
title: merge_request.title,
description: merge_request.description,
assignee_ids: merge_request.assignee_ids,
source_project: merge_request.project,
author: merge_request.author
)
2021-04-29 21:17:54 +05:30
2021-06-08 01:23:25 +05:30
update_service = ::MergeRequests::UpdateService.new(project: project, current_user: user, params: opts)
2021-04-29 21:17:54 +05:30
expect { service.execute(merge_request) }
.to issue_fewer_queries_than { update_service.execute(other_mr) }
end
end
end
end