FIX: flag as notify_moderators pm's used 'Regular' notification level for members of the moderators group, which isn't valid for pm's

This commit is contained in:
Neil Lalonde 2014-06-24 12:31:36 -04:00
parent b43ea8bcd1
commit 8e382fa5ea
2 changed files with 15 additions and 8 deletions

View File

@ -30,8 +30,11 @@ class TopicCreator
@topic.notifier.watch_topic!(@topic.user_id) @topic.notifier.watch_topic!(@topic.user_id)
end end
@topic.topic_allowed_users.pluck(:user_id).reject{|id| id == @topic.user_id}.each do |id| user_ids = @topic.topic_allowed_users(true).pluck(:user_id)
@topic.notifier.watch_topic!(id, nil) user_ids += @topic.topic_allowed_groups(true).map { |t| t.group.users.pluck(:id) }.flatten
user_ids.uniq.reject{ |id| id == @topic.user_id }.each do |user_id|
@topic.notifier.watch_topic!(user_id, nil) unless user_id == -1
end end
CategoryUser.auto_watch_new_topic(@topic) CategoryUser.auto_watch_new_topic(@topic)

View File

@ -18,6 +18,8 @@ describe PostAction do
it "notify moderators integration test" do it "notify moderators integration test" do
post = create_post post = create_post
mod = moderator mod = moderator
Group.refresh_automatic_groups!
action = PostAction.act(codinghorror, post, PostActionType.types[:notify_moderators], message: "this is my special long message"); action = PostAction.act(codinghorror, post, PostActionType.types[:notify_moderators], message: "this is my special long message");
posts = Post.joins(:topic) posts = Post.joins(:topic)
@ -29,13 +31,15 @@ describe PostAction do
action.related_post_id.should == posts[0].id.to_i action.related_post_id.should == posts[0].id.to_i
posts[0].subtype.should == TopicSubtype.notify_moderators posts[0].subtype.should == TopicSubtype.notify_moderators
# Moderators should be invited to the private topic, otherwise they're not permitted to see it topic = posts[0].topic
topic_user_ids = posts[0].topic.topic_users.map {|x| x.user_id}
topic_user_ids.should include(codinghorror.id)
topic_user_ids.should_not include(mod.id)
# invite the moderator # Moderators should be invited to the private topic, otherwise they're not permitted to see it
posts[0].topic.allowed_users << mod topic_user_ids = topic.topic_users(true).map {|x| x.user_id}
topic_user_ids.should include(codinghorror.id)
topic_user_ids.should include(mod.id)
# Notification level should be "Watching" for everyone
topic.topic_users(true).map(&:notification_level).uniq.should == [TopicUser.notification_levels[:watching]]
# reply to PM should clear flag # reply to PM should clear flag
p = PostCreator.new(mod, topic_id: posts[0].topic_id, raw: "This is my test reply to the user, it should clear flags") p = PostCreator.new(mod, topic_id: posts[0].topic_id, raw: "This is my test reply to the user, it should clear flags")