FIX: Create notification for group users when group has been invited.
https://meta.discourse.org/t/inviting-a-group-to-a-message-does-not-trigger-a-notification-mail/50509
This commit is contained in:
parent
5ce8d7a8c5
commit
2fdf9068eb
|
@ -719,6 +719,21 @@ SQL
|
||||||
# ensure all the notifications are out
|
# ensure all the notifications are out
|
||||||
PostAlerter.new.after_save_post(last_post)
|
PostAlerter.new.after_save_post(last_post)
|
||||||
add_small_action(user, "invited_group", group.name)
|
add_small_action(user, "invited_group", group.name)
|
||||||
|
|
||||||
|
group.users.where(
|
||||||
|
"group_users.notification_level > ?", NotificationLevels.all[:muted]
|
||||||
|
).find_each do |u|
|
||||||
|
|
||||||
|
u.notifications.create!(
|
||||||
|
notification_type: Notification.types[:invited_to_private_message],
|
||||||
|
topic_id: self.id,
|
||||||
|
post_number: 1,
|
||||||
|
data: {
|
||||||
|
topic_title: self.title,
|
||||||
|
display_username: user.username
|
||||||
|
}.to_json
|
||||||
|
)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
true
|
true
|
||||||
|
|
|
@ -439,22 +439,42 @@ describe Topic do
|
||||||
let(:walter) { Fabricate(:walter_white) }
|
let(:walter) { Fabricate(:walter_white) }
|
||||||
|
|
||||||
context 'by group name' do
|
context 'by group name' do
|
||||||
|
let(:group) { Fabricate(:group) }
|
||||||
|
|
||||||
it 'can add admin to allowed groups' do
|
it 'can add admin to allowed groups' do
|
||||||
admins = Group[:admins]
|
admins = Group[:admins]
|
||||||
admins.alias_level = Group::ALIAS_LEVELS[:everyone]
|
admins.update!(alias_level: Group::ALIAS_LEVELS[:everyone])
|
||||||
admins.save
|
|
||||||
|
|
||||||
expect(topic.invite_group(topic.user, admins)).to eq(true)
|
expect(topic.invite_group(topic.user, admins)).to eq(true)
|
||||||
|
|
||||||
expect(topic.allowed_groups.include?(admins)).to eq(true)
|
expect(topic.allowed_groups.include?(admins)).to eq(true)
|
||||||
|
|
||||||
expect(topic.remove_allowed_group(topic.user, 'admins')).to eq(true)
|
expect(topic.remove_allowed_group(topic.user, 'admins')).to eq(true)
|
||||||
topic.reload
|
|
||||||
|
|
||||||
expect(topic.allowed_groups.include?(admins)).to eq(false)
|
expect(topic.allowed_groups.include?(admins)).to eq(false)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
it 'creates a notification for each user in the group' do
|
||||||
|
user = Fabricate(:user)
|
||||||
|
user_2 = Fabricate(:user)
|
||||||
|
Fabricate(:post, topic: topic)
|
||||||
|
|
||||||
|
group.add(user)
|
||||||
|
group.add(user_2)
|
||||||
|
|
||||||
|
group.group_users.find_by(user: user_2).update!(
|
||||||
|
notification_level: NotificationLevels.all[:muted]
|
||||||
|
)
|
||||||
|
|
||||||
|
expect { topic.invite_group(topic.user, group) }
|
||||||
|
.to change { Notification.count }.by(1)
|
||||||
|
|
||||||
|
notification = Notification.last
|
||||||
|
|
||||||
|
expect(notification.user).to eq(user)
|
||||||
|
expect(notification.topic).to eq(topic)
|
||||||
|
|
||||||
|
expect(notification.notification_type)
|
||||||
|
.to eq(Notification.types[:invited_to_private_message])
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context 'by username' do
|
context 'by username' do
|
||||||
|
|
Loading…
Reference in New Issue