FIX: Never enqueue private messages

This commit is contained in:
Robin Ward 2015-05-04 11:07:46 -04:00
parent 5c7b984d2f
commit 7e3eaf5b02
2 changed files with 25 additions and 0 deletions

View File

@ -50,6 +50,9 @@ class NewPostManager
def perform def perform
# We never queue private messages
return perform_create_post if @args[:archetype] == Archetype.private_message
# Perform handlers until one returns a result # Perform handlers until one returns a result
handled = NewPostManager.handlers.any? do |handler| handled = NewPostManager.handlers.any? do |handler|
result = handler.call(self) result = handler.call(self)

View File

@ -17,6 +17,27 @@ describe NewPostManager do
end end
end end
context "default action" do
let(:other_user) { Fabricate(:user) }
it "doesn't enqueue private messages" do
manager = NewPostManager.new(topic.user,
raw: 'this is a new post',
title: 'this is a new title',
archetype: Archetype.private_message,
target_usernames: other_user.username)
SiteSetting.approve_unless_trust_level = 4
result = manager.perform
expect(result.action).to eq(:create_post)
expect(result).to be_success
expect(result.post).to be_present
expect(result.post.topic.private_message?).to eq(true)
expect(result.post).to be_a(Post)
end
end
context "default handler" do context "default handler" do
let(:manager) { NewPostManager.new(topic.user, raw: 'this is new post content', topic_id: topic.id) } let(:manager) { NewPostManager.new(topic.user, raw: 'this is new post content', topic_id: topic.id) }
@ -54,6 +75,7 @@ describe NewPostManager do
expect(result.action).to eq(:enqueued) expect(result.action).to eq(:enqueued)
end end
end end
end end
context "extensibility priority" do context "extensibility priority" do