FIX: mention notification takes precedence over group (#12407)

When a specific user is mentioned and group to which this user belongs, a direct mention notification should take precedence.
This commit is contained in:
Krzysztof Kotlarek 2021-03-17 08:20:41 +11:00 committed by GitHub
parent 37c42a57b0
commit 146775072a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 12 additions and 5 deletions

View File

@ -70,15 +70,15 @@ class PostAlerter
mentioned_opts = { user_id: editor.id, original_username: editor.username, display_username: editor.username } mentioned_opts = { user_id: editor.id, original_username: editor.username, display_username: editor.username }
end end
expand_group_mentions(mentioned_groups, post) do |group, users|
users = only_allowed_users(users, post)
notified += notify_users(users - notified, :group_mentioned, post, mentioned_opts.merge(group: group))
end
if mentioned_users if mentioned_users
mentioned_users = only_allowed_users(mentioned_users, post) mentioned_users = only_allowed_users(mentioned_users, post)
notified += notify_users(mentioned_users - notified, :mentioned, post, mentioned_opts) notified += notify_users(mentioned_users - notified, :mentioned, post, mentioned_opts)
end end
expand_group_mentions(mentioned_groups, post) do |group, users|
users = only_allowed_users(users, post)
notified += notify_users(users - notified, :group_mentioned, post, mentioned_opts.merge(group: group))
end
end end
# replies # replies

View File

@ -380,6 +380,13 @@ describe PostAlerter do
expect(GroupMention.count).to eq(4) expect(GroupMention.count).to eq(4)
end end
it 'takes private mention as precedence' do
expect {
create_post_with_alerts(raw: "Hello @group and @eviltrout, nice to meet you")
}.to change(evil_trout.notifications, :count).by(1)
expect(evil_trout.notifications.last.notification_type).to eq(Notification.types[:mentioned])
end
it "triggers :before_create_notifications_for_users" do it "triggers :before_create_notifications_for_users" do
events = DiscourseEvent.track_events do events = DiscourseEvent.track_events do
post post