Commit 444e888a authored by Mark Chao's avatar Mark Chao

Fix nil approvals_before_merge migrated as 0 approvals_required

MR#approvals_before_merge can be set to nil,
and in UX it means use project setting.
Simulate this behavior by updating with project setting.
parent 22d4a103
...@@ -50,7 +50,8 @@ module EE ...@@ -50,7 +50,8 @@ module EE
return if merge_request.merged? return if merge_request.merged?
return unless merge_request.previous_changes.include?(:approvals_before_merge) return unless merge_request.previous_changes.include?(:approvals_before_merge)
merge_request.approval_rules.regular.update_all(approvals_required: merge_request.approvals_before_merge) approvals_required = merge_request.approvals_before_merge || merge_request.target_project.approvals_before_merge
merge_request.approval_rules.regular.update_all(approvals_required: approvals_required)
end end
end end
end end
......
...@@ -57,6 +57,10 @@ module Gitlab ...@@ -57,6 +57,10 @@ module Gitlab
belongs_to :target_project, class_name: "Project" belongs_to :target_project, class_name: "Project"
has_many :approval_rules, class_name: 'ApprovalMergeRequestRule' has_many :approval_rules, class_name: 'ApprovalMergeRequestRule'
def approvals_required
approvals_before_merge || target_project.approvals_before_merge
end
def approver_ids def approver_ids
@approver_ids ||= Approver.where(target_type: 'MergeRequest', target_id: id).joins(:user).pluck('distinct user_id') @approver_ids ||= Approver.where(target_type: 'MergeRequest', target_id: id).joins(:user).pluck('distinct user_id')
end end
...@@ -86,6 +90,10 @@ module Gitlab ...@@ -86,6 +90,10 @@ module Gitlab
def approver_group_ids def approver_group_ids
@approver_group_ids ||= ApproverGroup.where(target_type: 'Project', target_id: id).joins(:group).pluck('distinct group_id') @approver_group_ids ||= ApproverGroup.where(target_type: 'Project', target_id: id).joins(:group).pluck('distinct group_id')
end end
def approvals_required
approvals_before_merge
end
end end
class User < ActiveRecord::Base class User < ActiveRecord::Base
...@@ -154,7 +162,7 @@ module Gitlab ...@@ -154,7 +162,7 @@ module Gitlab
unless rule.persisted? unless rule.persisted?
rule.name ||= ApprovalRuleLike::DEFAULT_NAME rule.name ||= ApprovalRuleLike::DEFAULT_NAME
rule.approvals_required = target.approvals_before_merge || 0 rule.approvals_required = target.approvals_required
rule.save! rule.save!
end end
......
...@@ -44,14 +44,27 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do ...@@ -44,14 +44,27 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do
end.to change { approval_rule.users.count }.by(1) end.to change { approval_rule.users.count }.by(1)
.and change { approval_rule.groups.count }.by(1) .and change { approval_rule.groups.count }.by(1)
approval_rule = target.approval_rules.first expect(target.approval_rules.regular.first).to eq(approval_rule)
expect(approval_rule.approvals_required).to eq(0)
expect(approval_rule.name).to eq('Default')
expect(approval_rule.users).to contain_exactly(user1) expect(approval_rule.users).to contain_exactly(user1)
expect(approval_rule.groups).to contain_exactly(group1) expect(approval_rule.groups).to contain_exactly(group1)
end end
context 'when rule is not created yet' do
let(:approval_rule) { nil }
it 'creates rule in new schema' do
described_class.new.perform(target_type, target.id)
approval_rule = target.approval_rules.regular.first
expect(approval_rule.approvals_required).to eq(2)
expect(approval_rule.name).to eq('Default')
expect(approval_rule.users).to contain_exactly(user1)
expect(approval_rule.groups).to contain_exactly(group1)
end
end
end end
context 'when member not in old schema but in new schema' do context 'when member not in old schema but in new schema' do
...@@ -98,7 +111,7 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do ...@@ -98,7 +111,7 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do
end end
context 'merge request' do context 'merge request' do
let(:target) { create(:merge_request) } let(:target) { create(:merge_request, approvals_before_merge: 2) }
let(:target_type) { 'MergeRequest' } let(:target_type) { 'MergeRequest' }
let(:approval_rule) { create(:approval_merge_request_rule, merge_request: target) } let(:approval_rule) { create(:approval_merge_request_rule, merge_request: target) }
...@@ -128,6 +141,18 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do ...@@ -128,6 +141,18 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do
end end
end end
context 'when approvals_before_merge is nil' do
it "updates with project's approvals_required" do
target.target_project.update(approvals_before_merge: 3)
target.update(approvals_before_merge: nil)
create_member_in(create(:user), :old_schema)
described_class.new.perform(target_type, target.id)
expect(target.approval_rules.regular.first.approvals_required).to eq(3)
end
end
context 'when approver is no longer overwritten' do context 'when approver is no longer overwritten' do
before do before do
create_member_in(create(:user), :new_schema) create_member_in(create(:user), :new_schema)
...@@ -196,7 +221,7 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do ...@@ -196,7 +221,7 @@ describe Gitlab::BackgroundMigration::MigrateApproverToApprovalRules do
end end
context 'project' do context 'project' do
let(:target) { create(:project) } let(:target) { create(:project, approvals_before_merge: 2) }
let(:target_type) { 'Project' } let(:target_type) { 'Project' }
let(:approval_rule) { create(:approval_project_rule, project: target) } let(:approval_rule) { create(:approval_project_rule, project: target) }
......
...@@ -58,14 +58,25 @@ describe MergeRequests::UpdateService, :mailer do ...@@ -58,14 +58,25 @@ describe MergeRequests::UpdateService, :mailer do
end end
context 'when approvals_before_merge changes' do context 'when approvals_before_merge changes' do
it "updates approval_rules' approvals_required" do using RSpec::Parameterized::TableSyntax
rule = create(:approval_merge_request_rule, merge_request: merge_request)
code_owner_rule = create(:approval_merge_request_rule, merge_request: merge_request, code_owner: true)
update_merge_request(approvals_before_merge: 42) where(:project_value, :mr_before_value, :mr_after_value, :result) do
3 | 4 | 5 | 5
3 | 4 | nil | 3
3 | nil | 5 | 5
end
with_them do
let(:project) { create(:project, :repository, approvals_before_merge: project_value) }
it "updates approval_rules' approvals_required" do
merge_request.update(approvals_before_merge: mr_before_value)
rule = create(:approval_merge_request_rule, merge_request: merge_request)
update_merge_request(approvals_before_merge: mr_after_value)
expect(rule.reload.approvals_required).to eq(42) expect(rule.reload.approvals_required).to eq(result)
expect(code_owner_rule.reload.approvals_required).to eq(0) end
end end
end end
end end
......
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