mirror of
https://github.com/discourse/discourse.git
synced 2025-01-18 12:53:17 +08:00
Revert "FIX: TL0 users' messages to moderators were not being posted when flagging private messages"
This commit is contained in:
parent
dfdf12c92f
commit
4452d67a23
|
@ -292,10 +292,8 @@ class Guardian
|
||||||
(is_group || is_user) &&
|
(is_group || is_user) &&
|
||||||
# User is authenticated
|
# User is authenticated
|
||||||
authenticated? &&
|
authenticated? &&
|
||||||
# Have to be a basic level at least, or are contacting moderators
|
# Have to be a basic level at least
|
||||||
(@user.has_trust_level?(SiteSetting.min_trust_to_send_messages) ||
|
@user.has_trust_level?(SiteSetting.min_trust_to_send_messages) &&
|
||||||
(target.is_a?(User) && target.moderator?) ||
|
|
||||||
(target.name == Group[:moderators].name)) &&
|
|
||||||
# User disabled private message
|
# User disabled private message
|
||||||
(is_staff? || is_group || target.user_option.allow_private_messages) &&
|
(is_staff? || is_group || target.user_option.allow_private_messages) &&
|
||||||
# PMs are enabled
|
# PMs are enabled
|
||||||
|
|
|
@ -154,22 +154,9 @@ describe Guardian do
|
||||||
expect(Guardian.new(user).can_send_private_message?(user)).to be_truthy
|
expect(Guardian.new(user).can_send_private_message?(user)).to be_truthy
|
||||||
end
|
end
|
||||||
|
|
||||||
context "when user is untrusted " do
|
it "returns false when you are untrusted" do
|
||||||
before do
|
user.trust_level = TrustLevel[0]
|
||||||
user.trust_level = TrustLevel[0]
|
expect(Guardian.new(user).can_send_private_message?(another_user)).to be_falsey
|
||||||
end
|
|
||||||
|
|
||||||
it "returns false to another user" do
|
|
||||||
expect(Guardian.new(user).can_send_private_message?(another_user)).to be_falsey
|
|
||||||
end
|
|
||||||
|
|
||||||
it "returns true to moderator user" do
|
|
||||||
expect(Guardian.new(user).can_send_private_message?(moderator)).to be_truthy
|
|
||||||
end
|
|
||||||
|
|
||||||
it "returns true to moderator group" do
|
|
||||||
expect(Guardian.new(user).can_send_private_message?(Group[:moderators])).to be_truthy
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns true to another user" do
|
it "returns true to another user" do
|
||||||
|
@ -193,10 +180,6 @@ describe Guardian do
|
||||||
expect(Guardian.new(moderator).can_send_private_message?(another_user)).to be_truthy
|
expect(Guardian.new(moderator).can_send_private_message?(another_user)).to be_truthy
|
||||||
expect(Guardian.new(admin).can_send_private_message?(another_user)).to be_truthy
|
expect(Guardian.new(admin).can_send_private_message?(another_user)).to be_truthy
|
||||||
end
|
end
|
||||||
|
|
||||||
it "returns false even to a moderator" do
|
|
||||||
expect(Guardian.new(trust_level_4).can_send_private_message?(moderator)).to be_falsey
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
context "target user is suspended" do
|
context "target user is suspended" do
|
||||||
|
|
|
@ -3,12 +3,11 @@ require 'rails_helper'
|
||||||
describe TopicCreator do
|
describe TopicCreator do
|
||||||
|
|
||||||
let(:user) { Fabricate(:user, trust_level: TrustLevel[2]) }
|
let(:user) { Fabricate(:user, trust_level: TrustLevel[2]) }
|
||||||
let(:user2) { Fabricate(:user, trust_level: TrustLevel[2]) }
|
|
||||||
let(:moderator) { Fabricate(:moderator) }
|
let(:moderator) { Fabricate(:moderator) }
|
||||||
let(:admin) { Fabricate(:admin) }
|
let(:admin) { Fabricate(:admin) }
|
||||||
|
|
||||||
let(:valid_attrs) { Fabricate.attributes_for(:topic) }
|
let(:valid_attrs) { Fabricate.attributes_for(:topic) }
|
||||||
let(:pm_valid_attrs) { { raw: 'this is a new post', title: 'this is a new title', archetype: Archetype.private_message, target_usernames: user2.username } }
|
let(:pm_valid_attrs) { { raw: 'this is a new post', title: 'this is a new title', archetype: Archetype.private_message, target_usernames: moderator.username } }
|
||||||
|
|
||||||
let(:pm_to_email_valid_attrs) do
|
let(:pm_to_email_valid_attrs) do
|
||||||
{
|
{
|
||||||
|
|
|
@ -42,88 +42,62 @@ describe PostAction do
|
||||||
expect { PostAction.act(admin, post, PostActionType.types[:notify_user], message: "WAT") }.not_to raise_error
|
expect { PostAction.act(admin, post, PostActionType.types[:notify_user], message: "WAT") }.not_to raise_error
|
||||||
end
|
end
|
||||||
|
|
||||||
context "notify moderators integration test" do
|
it "notify moderators integration test" do
|
||||||
let!(:mod) { moderator }
|
post = create_post
|
||||||
|
mod = moderator
|
||||||
|
Group.refresh_automatic_groups!
|
||||||
|
|
||||||
before { Group.refresh_automatic_groups! }
|
action = PostAction.act(codinghorror, post, PostActionType.types[:notify_moderators], message: "this is my special long message")
|
||||||
|
|
||||||
it "flag from TL1 user" do
|
posts = Post.joins(:topic)
|
||||||
post = create_post
|
.select('posts.id, topics.subtype, posts.topic_id')
|
||||||
|
.where('topics.archetype' => Archetype.private_message)
|
||||||
|
.to_a
|
||||||
|
|
||||||
action = PostAction.act(codinghorror, post, PostActionType.types[:notify_moderators], message: "this is my special long message")
|
expect(posts.count).to eq(1)
|
||||||
|
expect(action.related_post_id).to eq(posts[0].id.to_i)
|
||||||
|
expect(posts[0].subtype).to eq(TopicSubtype.notify_moderators)
|
||||||
|
|
||||||
posts = Post.joins(:topic)
|
topic = posts[0].topic
|
||||||
.select('posts.id, topics.subtype, posts.topic_id')
|
|
||||||
.where('topics.archetype' => Archetype.private_message)
|
|
||||||
.to_a
|
|
||||||
|
|
||||||
expect(posts.count).to eq(1)
|
# Moderators should be invited to the private topic, otherwise they're not permitted to see it
|
||||||
expect(action.related_post_id).to eq(posts[0].id.to_i)
|
topic_user_ids = topic.reload.topic_users.map { |x| x.user_id }
|
||||||
expect(posts[0].subtype).to eq(TopicSubtype.notify_moderators)
|
expect(topic_user_ids).to include(codinghorror.id)
|
||||||
|
expect(topic_user_ids).to include(mod.id)
|
||||||
|
|
||||||
topic = posts[0].topic
|
expect(topic.topic_users.where(user_id: mod.id)
|
||||||
|
.pluck(:notification_level).first).to eq(TopicUser.notification_levels[:tracking])
|
||||||
|
|
||||||
# Moderators should be invited to the private topic, otherwise they're not permitted to see it
|
expect(topic.topic_users.where(user_id: codinghorror.id)
|
||||||
topic_user_ids = topic.reload.topic_users.map { |x| x.user_id }
|
.pluck(:notification_level).first).to eq(TopicUser.notification_levels[:watching])
|
||||||
expect(topic_user_ids).to include(codinghorror.id)
|
|
||||||
expect(topic_user_ids).to include(mod.id)
|
|
||||||
|
|
||||||
expect(topic.topic_users.where(user_id: mod.id)
|
# reply to PM should not clear flag
|
||||||
.pluck(:notification_level).first).to eq(TopicUser.notification_levels[:tracking])
|
PostCreator.new(mod, topic_id: posts[0].topic_id, raw: "This is my test reply to the user, it should clear flags").create
|
||||||
|
action.reload
|
||||||
|
expect(action.deleted_at).to eq(nil)
|
||||||
|
|
||||||
expect(topic.topic_users.where(user_id: codinghorror.id)
|
# Acting on the flag should not post an automated status message (since a moderator already replied)
|
||||||
.pluck(:notification_level).first).to eq(TopicUser.notification_levels[:watching])
|
expect(topic.posts.count).to eq(2)
|
||||||
|
PostAction.agree_flags!(post, admin)
|
||||||
|
topic.reload
|
||||||
|
expect(topic.posts.count).to eq(2)
|
||||||
|
|
||||||
# reply to PM should not clear flag
|
# Clearing the flags should not post an automated status message
|
||||||
PostCreator.new(mod, topic_id: posts[0].topic_id, raw: "This is my test reply to the user, it should clear flags").create
|
PostAction.act(mod, post, PostActionType.types[:notify_moderators], message: "another special message")
|
||||||
action.reload
|
PostAction.clear_flags!(post, admin)
|
||||||
expect(action.deleted_at).to eq(nil)
|
topic.reload
|
||||||
|
expect(topic.posts.count).to eq(2)
|
||||||
|
|
||||||
# Acting on the flag should not post an automated status message (since a moderator already replied)
|
# Acting on the flag should post an automated status message
|
||||||
expect(topic.posts.count).to eq(2)
|
another_post = create_post
|
||||||
PostAction.agree_flags!(post, admin)
|
action = PostAction.act(codinghorror, another_post, PostActionType.types[:notify_moderators], message: "foobar")
|
||||||
topic.reload
|
topic = action.related_post.topic
|
||||||
expect(topic.posts.count).to eq(2)
|
|
||||||
|
|
||||||
# Clearing the flags should not post an automated status message
|
expect(topic.posts.count).to eq(1)
|
||||||
PostAction.act(mod, post, PostActionType.types[:notify_moderators], message: "another special message")
|
PostAction.agree_flags!(another_post, admin)
|
||||||
PostAction.clear_flags!(post, admin)
|
topic.reload
|
||||||
topic.reload
|
expect(topic.posts.count).to eq(2)
|
||||||
expect(topic.posts.count).to eq(2)
|
expect(topic.posts.last.post_type).to eq(Post.types[:moderator_action])
|
||||||
|
|
||||||
# Acting on the flag should post an automated status message
|
|
||||||
another_post = create_post
|
|
||||||
action = PostAction.act(codinghorror, another_post, PostActionType.types[:notify_moderators], message: "foobar")
|
|
||||||
topic = action.related_post.topic
|
|
||||||
|
|
||||||
expect(topic.posts.count).to eq(1)
|
|
||||||
PostAction.agree_flags!(another_post, admin)
|
|
||||||
topic.reload
|
|
||||||
expect(topic.posts.count).to eq(2)
|
|
||||||
expect(topic.posts.last.post_type).to eq(Post.types[:moderator_action])
|
|
||||||
end
|
|
||||||
|
|
||||||
it "flag from TL0 user" do
|
|
||||||
tl0_user = Fabricate(:user, trust_level: 0)
|
|
||||||
first_post = Fabricate(:post, user: Fabricate(:user, trust_level: 1))
|
|
||||||
|
|
||||||
pm_topic = Fabricate(:private_message_topic,
|
|
||||||
first_post: first_post,
|
|
||||||
topic_allowed_users: [
|
|
||||||
Fabricate.build(:topic_allowed_user, user: first_post.user),
|
|
||||||
Fabricate.build(:topic_allowed_user, user: tl0_user),
|
|
||||||
]
|
|
||||||
)
|
|
||||||
|
|
||||||
action = PostAction.act(tl0_user, first_post, PostActionType.types[:notify_moderators], message: 'my special message')
|
|
||||||
|
|
||||||
expect(action.related_post_id).to be_present
|
|
||||||
|
|
||||||
notify_moderators_post = action.related_post
|
|
||||||
|
|
||||||
expect(notify_moderators_post.topic&.subtype).to eq(TopicSubtype.notify_moderators)
|
|
||||||
expect(notify_moderators_post.raw).to include('my special message')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
describe 'notify_moderators' do
|
describe 'notify_moderators' do
|
||||||
|
|
Loading…
Reference in New Issue
Block a user