Commit e83fcf75 authored by Igor Drozdov's avatar Igor Drozdov

Merge branch '325691-add-sync_code_onwers_approval_rules_worker' into 'master'

Add new MergeRequests::SyncCodeOwnerApprovalRulesWorker

See merge request gitlab-org/gitlab!58512
parents 20288722 ba5c9f62
---
title: Add new MergeRequests::SyncCodeOwnerApprovalRulesWorker
merge_request: 58512
author:
type: performance
...@@ -220,6 +220,8 @@ ...@@ -220,6 +220,8 @@
- 1 - 1
- - merge_requests_resolve_todos - - merge_requests_resolve_todos
- 1 - 1
- - merge_requests_sync_code_owner_approval_rules
- 1
- - metrics_dashboard_prune_old_annotations - - metrics_dashboard_prune_old_annotations
- 1 - 1
- - metrics_dashboard_sync_dashboards - - metrics_dashboard_sync_dashboards
......
...@@ -39,7 +39,9 @@ module EE ...@@ -39,7 +39,9 @@ module EE
def after_update(merge_request) def after_update(merge_request)
super super
::MergeRequests::SyncCodeOwnerApprovalRules.new(merge_request).execute merge_request.run_after_commit do
::MergeRequests::SyncCodeOwnerApprovalRulesWorker.perform_async(merge_request)
end
end end
override :create_branch_change_note override :create_branch_change_note
......
...@@ -867,6 +867,14 @@ ...@@ -867,6 +867,14 @@
:weight: 1 :weight: 1
:idempotent: :idempotent:
:tags: [] :tags: []
- :name: merge_requests_sync_code_owner_approval_rules
:feature_category: :source_code_management
:has_external_dependencies:
:urgency: :high
:resource_boundary: :unknown
:weight: 1
:idempotent: true
:tags: []
- :name: new_epic - :name: new_epic
:feature_category: :epics :feature_category: :epics
:has_external_dependencies: :has_external_dependencies:
......
# frozen_string_literal: true
module MergeRequests
class SyncCodeOwnerApprovalRulesWorker
include ApplicationWorker
feature_category :source_code_management
urgency :high
deduplicate :until_executed
idempotent!
def perform(merge_request_id)
merge_request = MergeRequest.find_by_id(merge_request_id)
return unless merge_request
::MergeRequests::SyncCodeOwnerApprovalRules.new(merge_request).execute
end
end
end
...@@ -302,12 +302,13 @@ RSpec.describe MergeRequests::UpdateService, :mailer do ...@@ -302,12 +302,13 @@ RSpec.describe MergeRequests::UpdateService, :mailer do
end end
end end
it 'updates code owner approval rules' do context 'when called inside an ActiveRecord transaction' do
expect_next_instance_of(::MergeRequests::SyncCodeOwnerApprovalRules) do |instance| it 'does not attempt to update code owner approval rules' do
expect(instance).to receive(:execute) allow(ActiveRecord::Base.connection).to receive(:transaction_open?).and_return(true)
end expect(::MergeRequests::SyncCodeOwnerApprovalRulesWorker).not_to receive(:perform_async)
update_merge_request(title: 'Title') update_merge_request(title: 'Title')
end
end end
context 'updating reviewers_ids' do context 'updating reviewers_ids' do
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Milestones::DestroyService do
let(:user) { create(:user) }
let(:project) { create(:project, :repository) }
let(:milestone) { create(:milestone, title: 'Milestone v1.0', project: project) }
before do
project.add_maintainer(user)
end
def service
described_class.new(project, user, {})
end
describe '#execute' do
context 'with an existing merge request' do
let!(:issue) { create(:issue, project: project, milestone: milestone) }
let!(:merge_request) { create(:merge_request, source_project: project, milestone: milestone) }
it 'manually queues MergeRequests::SyncCodeOwnerApprovalRulesWorker jobs' do
expect(::MergeRequests::SyncCodeOwnerApprovalRulesWorker).to receive(:perform_async)
service.execute(milestone)
end
end
end
end
# frozen_string_literal: true
require "spec_helper"
RSpec.describe MergeRequests::SyncCodeOwnerApprovalRulesWorker do
let_it_be(:merge_request) { create(:merge_request) }
subject { described_class.new }
describe "#perform" do
it_behaves_like 'an idempotent worker' do
let(:job_args) { [merge_request.id] }
end
context "when merge request is not found" do
it "returns without attempting to sync code owner rules" do
expect(MergeRequests::SyncCodeOwnerApprovalRules).not_to receive(:new)
subject.perform(non_existing_record_id)
end
end
context "when merge request is found" do
it "attempts to sync code owner rules" do
expect_next_instance_of(::MergeRequests::SyncCodeOwnerApprovalRules) do |instance|
expect(instance).to receive(:execute)
end
subject.perform(merge_request.id)
end
end
end
end
...@@ -22,14 +22,16 @@ RSpec.describe Milestones::DestroyService do ...@@ -22,14 +22,16 @@ RSpec.describe Milestones::DestroyService do
expect { milestone.reload }.to raise_error ActiveRecord::RecordNotFound expect { milestone.reload }.to raise_error ActiveRecord::RecordNotFound
end end
it 'deletes milestone id from issuables' do context 'with an existing merge request' do
issue = create(:issue, project: project, milestone: milestone) let!(:issue) { create(:issue, project: project, milestone: milestone) }
merge_request = create(:merge_request, source_project: project, milestone: milestone) let!(:merge_request) { create(:merge_request, source_project: project, milestone: milestone) }
service.execute(milestone) it 'deletes milestone id from issuables' do
service.execute(milestone)
expect(issue.reload.milestone).to be_nil expect(issue.reload.milestone).to be_nil
expect(merge_request.reload.milestone).to be_nil expect(merge_request.reload.milestone).to be_nil
end
end end
it 'logs destroy event' do it 'logs destroy event' do
......
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