Commit 9f8ad0ad authored by Ruben Davila's avatar Ruben Davila

Merge remote-tracking branch 'dev/master'

parents 5fbadf3d ca6c6991
Please view this file on the master branch, on stable branches it's out of date. Please view this file on the master branch, on stable branches it's out of date.
v 8.12.0 (Unreleased) v 8.12.0 (Unreleased)
v 8.11.6
- Exclude blocked users from potential MR approvers
v 8.11.5 v 8.11.5
- API: Restore backward-compatibility for POST /projects/:id/members when membership is locked - API: Restore backward-compatibility for POST /projects/:id/members when membership is locked
......
...@@ -677,7 +677,10 @@ class MergeRequest < ActiveRecord::Base ...@@ -677,7 +677,10 @@ class MergeRequest < ActiveRecord::Base
wheres << "id IN (#{project.group.members.where(has_access).select(:user_id).to_sql})" wheres << "id IN (#{project.group.members.where(has_access).select(:user_id).to_sql})"
end end
User.where("(#{wheres.join(' OR ')}) AND id NOT IN (#{approvals.select(:user_id).to_sql}) AND id != #{author.id}").count User.
active.
where("(#{wheres.join(' OR ')}) AND id NOT IN (#{approvals.select(:user_id).to_sql}) AND id != #{author.id}").
count
end end
# Users in the list of approvers who have not already approved this MR. # Users in the list of approvers who have not already approved this MR.
......
...@@ -336,6 +336,15 @@ describe MergeRequest, models: true do ...@@ -336,6 +336,15 @@ describe MergeRequest, models: true do
end.to change { merge_request.number_of_potential_approvers }.by(1) end.to change { merge_request.number_of_potential_approvers }.by(1)
end end
it "excludes blocked users" do
developer = create(:user)
blocked_developer = create(:user).tap { |u| u.block! }
project.team << [developer, :developer]
project.team << [blocked_developer, :developer]
expect(merge_request.number_of_potential_approvers).to eq(1)
end
context "when the project is part of a group" do context "when the project is part of a group" do
let(:group) { create(:group) } let(:group) { create(:group) }
before { project.update_attributes(group: group) } before { project.update_attributes(group: group) }
...@@ -346,6 +355,8 @@ describe MergeRequest, models: true do ...@@ -346,6 +355,8 @@ describe MergeRequest, models: true do
group.add_reporter(create(:user)) group.add_reporter(create(:user))
group.add_developer(create(:user)) group.add_developer(create(:user))
group.add_master(create(:user)) group.add_master(create(:user))
blocked_developer = create(:user).tap { |u| u.block! }
group.add_developer(blocked_developer)
end.to change { merge_request.number_of_potential_approvers }.by(2) end.to change { merge_request.number_of_potential_approvers }.by(2)
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