FIX: post mover not clearing reply_to_user_id

This commit is contained in:
Sam 2017-06-01 18:00:04 -04:00
parent 062158a25e
commit a7fc93acac
2 changed files with 48 additions and 22 deletions

View File

@ -100,20 +100,19 @@ class PostMover
def move(post) def move(post)
@first_post_number_moved ||= post.post_number @first_post_number_moved ||= post.post_number
Post.where(id: post.id, topic_id: original_topic.id).update_all( update = {
[ reply_count: @reply_count[post.post_number] || 0,
['post_number = :post_number', post_number: @move_map[post.post_number],
'reply_to_post_number = :reply_to_post_number', reply_to_post_number: @move_map[post.reply_to_post_number],
'topic_id = :topic_id', topic_id: destination_topic.id,
'sort_order = :post_number', sort_order: @move_map[post.post_number]
'reply_count = :reply_count', }
].join(', '),
reply_count: @reply_count[post.post_number] || 0, unless @move_map[post.reply_to_post_number]
post_number: @move_map[post.post_number], update[:reply_to_user_id] = nil
reply_to_post_number: @move_map[post.reply_to_post_number], end
topic_id: destination_topic.id
] Post.where(id: post.id, topic_id: original_topic.id).update_all(update)
)
# Move any links from the post to the new topic # Move any links from the post to the new topic
post.topic_links.update_all(topic_id: destination_topic.id) post.topic_links.update_all(topic_id: destination_topic.id)

View File

@ -36,6 +36,7 @@ describe PostMover do
let!(:p3) { Fabricate(:post, topic: topic, reply_to_post_number: p1.post_number, user: user) } let!(:p3) { Fabricate(:post, topic: topic, reply_to_post_number: p1.post_number, user: user) }
let!(:p4) { Fabricate(:post, topic: topic, reply_to_post_number: p2.post_number, user: user) } let!(:p4) { Fabricate(:post, topic: topic, reply_to_post_number: p2.post_number, user: user) }
let!(:p5) { Fabricate(:post) } let!(:p5) { Fabricate(:post) }
let(:p6) { Fabricate(:post, topic: topic) }
before do before do
p1.replies << p3 p1.replies << p3
@ -46,15 +47,41 @@ describe PostMover do
context 'success' do context 'success' do
it "enqueues a job to notify users" do it "correctly handles notifications and bread crumbs" do
topic.stubs(:add_moderator_post) #topic.expects(:add_moderator_post).with(user, instance_of(String), has_entries(post_number: 2))
Jobs.expects(:enqueue).with(:notify_moved_posts, post_ids: [p2.id, p4.id], moved_by_id: user.id) #Jobs.expects(:enqueue).with(:notify_moved_posts, post_ids: [p2.id, p4.id], moved_by_id: user.id)
topic.move_posts(user, [p2.id, p4.id], title: "new testing topic name")
end
it "adds a moderator post at the location of the first moved post" do old_topic = p2.topic
topic.expects(:add_moderator_post).with(user, instance_of(String), has_entries(post_number: 2))
topic.move_posts(user, [p2.id, p4.id], title: "new testing topic name") old_topic_id = p2.topic_id
topic.move_posts(user, [p2.id, p4.id, p6.id], title: "new testing topic name")
p2.reload
expect(p2.topic_id).not_to eq(old_topic_id)
expect(p2.reply_to_post_number).to eq(nil)
expect(p2.reply_to_user_id).to eq(nil)
notification = p2.user.notifications.where(notification_type: Notification.types[:moved_post]).first
expect(notification.topic_id).to eq(p2.topic_id)
expect(notification.post_number).to eq(1)
# no message for person who made the move
expect(p4.user.notifications.where(notification_type: Notification.types[:moved_post]).length).to eq(0)
# notify at the right spot in the stream
notification = p6.user.notifications.where(notification_type: Notification.types[:moved_post]).first
expect(notification.topic_id).to eq(p2.topic_id)
# this is the 3rd post we moved
expect(notification.post_number).to eq(3)
old_topic.reload
move_message = old_topic.posts.find_by(post_number: 2)
expect(move_message.post_type).to eq(Post.types[:small_action])
expect(move_message.raw).to include("3 posts were split")
end end
end end