FIX: do not move small post actions

This commit is contained in:
Gerhard Schlager 2017-11-23 17:16:05 +01:00
parent 4bc2ce2f4d
commit 39810e4425
2 changed files with 28 additions and 2 deletions

View File

@ -158,7 +158,7 @@ class PostMover
message = I18n.with_locale(SiteSetting.default_locale) do message = I18n.with_locale(SiteSetting.default_locale) do
I18n.t("move_posts.#{move_type_str}_moderator_post", I18n.t("move_posts.#{move_type_str}_moderator_post",
count: post_ids.count, count: posts.length,
topic_link: "[#{destination_topic.title}](#{destination_topic.relative_url})") topic_link: "[#{destination_topic.title}](#{destination_topic.relative_url})")
end end
@ -172,7 +172,10 @@ class PostMover
def posts def posts
@posts ||= begin @posts ||= begin
Post.where(topic: @original_topic, id: post_ids).order(:created_at).tap do |posts| Post.where(topic: @original_topic, id: post_ids)
.where.not(post_type: Post.types[:small_action])
.order(:created_at).tap do |posts|
raise Discourse::InvalidParameters.new(:post_ids) if posts.empty? raise Discourse::InvalidParameters.new(:post_ids) if posts.empty?
end end
end end

View File

@ -247,6 +247,17 @@ describe PostMover do
expect(post.raw).to eq(expected_text) expect(post.raw).to eq(expected_text)
end end
it "does not try to move small action posts" do
small_action = Fabricate(:post, topic: topic, raw: "A small action", post_type: Post.types[:small_action])
new_topic = topic.move_posts(user, [p2.id, p4.id, small_action.id], title: "new testing topic name", category_id: category.id)
expect(new_topic.posts_count).to eq(2)
expect(small_action.topic_id).to eq(topic.id)
moderator_post = topic.posts.last
expect(moderator_post.raw).to include("2 posts were split")
end
end end
context "to an existing topic" do context "to an existing topic" do
@ -309,6 +320,18 @@ describe PostMover do
topic.reload topic.reload
expect(topic.closed).to eq(true) expect(topic.closed).to eq(true)
end end
it "does not try to move small action posts" do
small_action = Fabricate(:post, topic: topic, raw: "A small action", post_type: Post.types[:small_action])
moved_to = topic.move_posts(user, [p1.id, p2.id, p3.id, p4.id, small_action.id], destination_topic_id: destination_topic.id)
moved_to.reload
expect(moved_to.posts_count).to eq(5)
expect(small_action.topic_id).to eq(topic.id)
moderator_post = topic.posts.find_by(post_number: 2)
expect(moderator_post.raw).to include("4 posts were merged")
end
end end
context "moving the first post" do context "moving the first post" do