FIX: display warning only if all users already added to the group (#10500)
If at least one user can be added to the group, proceed with that action
This commit is contained in:
parent
daddad7fd6
commit
7833853cf1
|
@ -329,12 +329,12 @@ class GroupsController < ApplicationController
|
||||||
'usernames or emails must be present'
|
'usernames or emails must be present'
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
usernames_already_in_group = group.users.where(id: users.map(&:id)).pluck(:username)
|
||||||
if (usernames = group.users.where(id: users.map(&:id)).pluck(:username)).present?
|
if usernames_already_in_group.present? && usernames_already_in_group.length == users.length
|
||||||
render_json_error(I18n.t(
|
render_json_error(I18n.t(
|
||||||
"groups.errors.member_already_exist",
|
"groups.errors.member_already_exist",
|
||||||
username: usernames.sort.join(", "),
|
username: usernames_already_in_group.sort.join(", "),
|
||||||
count: usernames.size
|
count: usernames_already_in_group.size
|
||||||
))
|
))
|
||||||
else
|
else
|
||||||
uniq_users = users.uniq
|
uniq_users = users.uniq
|
||||||
|
|
|
@ -1213,11 +1213,25 @@ describe GroupsController do
|
||||||
expect(response.status).to eq(200)
|
expect(response.status).to eq(200)
|
||||||
end
|
end
|
||||||
|
|
||||||
it 'fails when multiple member already exists' do
|
it 'adds missing users even if some exists' do
|
||||||
user2.update!(username: 'alice')
|
user2.update!(username: 'alice')
|
||||||
user3 = Fabricate(:user, username: 'bob')
|
user3 = Fabricate(:user, username: 'bob')
|
||||||
[user2, user3].each { |user| group.add(user) }
|
[user2, user3].each { |user| group.add(user) }
|
||||||
|
|
||||||
|
expect do
|
||||||
|
put "/groups/#{group.id}/members.json",
|
||||||
|
params: { user_emails: [user1.email, user2.email, user3.email].join(",") }
|
||||||
|
end.to change { group.users.count }.by(1)
|
||||||
|
|
||||||
|
expect(response.status).to eq(200)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'displays warning when all members already exists' do
|
||||||
|
user1.update!(username: 'john')
|
||||||
|
user2.update!(username: 'alice')
|
||||||
|
user3 = Fabricate(:user, username: 'bob')
|
||||||
|
[user1, user2, user3].each { |user| group.add(user) }
|
||||||
|
|
||||||
expect do
|
expect do
|
||||||
put "/groups/#{group.id}/members.json",
|
put "/groups/#{group.id}/members.json",
|
||||||
params: { user_emails: [user1.email, user2.email, user3.email].join(",") }
|
params: { user_emails: [user1.email, user2.email, user3.email].join(",") }
|
||||||
|
@ -1227,8 +1241,8 @@ describe GroupsController do
|
||||||
|
|
||||||
expect(response.parsed_body["errors"]).to include(I18n.t(
|
expect(response.parsed_body["errors"]).to include(I18n.t(
|
||||||
"groups.errors.member_already_exist",
|
"groups.errors.member_already_exist",
|
||||||
username: "alice, bob",
|
username: "alice, bob, john",
|
||||||
count: 2
|
count: 3
|
||||||
))
|
))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue