posts: fix double deletion bug.

Fix a bug where, if a user a was deleting a post and they accidentally
clicked the delete button twice, it could create two flags.
This commit is contained in:
evazion
2022-09-24 23:27:06 -05:00
parent 361af6a4cb
commit 718c4d121b
8 changed files with 65 additions and 20 deletions

View File

@@ -17,7 +17,7 @@ class PostPrunerTest < ActiveSupport::TestCase
context "for a flagged post" do
should "prune expired flags" do
@post = create(:post, created_at: 4.weeks.ago, is_flagged: true)
@post = create(:post, created_at: 4.weeks.ago)
@flag = create(:post_flag, post: @post, created_at: 5.days.ago)
PostPruner.prune!
@@ -31,7 +31,7 @@ class PostPrunerTest < ActiveSupport::TestCase
end
should "not prune unexpired flags" do
@post = create(:post, created_at: 4.weeks.ago, is_flagged: true)
@post = create(:post, created_at: 4.weeks.ago)
@flag = create(:post_flag, post: @post, created_at: 1.day.ago)
PostPruner.prune!
@@ -44,10 +44,12 @@ class PostPrunerTest < ActiveSupport::TestCase
end
should "leave the status of old flags unchanged" do
@post = create(:post, created_at: 4.weeks.ago, is_flagged: true)
@post = create(:post, created_at: 4.weeks.ago)
@flag1 = create(:post_flag, post: @post, created_at: 3.weeks.ago, status: :succeeded)
@flag2 = create(:post_flag, post: @post, created_at: 2.weeks.ago, status: :rejected)
@flag3 = create(:post_flag, post: @post, created_at: 1.weeks.ago, status: :pending)
assert_equal(true, @post.is_flagged?)
PostPruner.prune!
assert_equal(true, @post.reload.is_deleted?)

View File

@@ -880,7 +880,7 @@ class PostQueryBuilderTest < ActiveSupport::TestCase
end
should "return posts for the status:unmoderated metatag" do
flagged = create(:post, is_flagged: true)
flagged = create(:post)
pending = create(:post, is_pending: true)
disapproved = create(:post, is_pending: true)
appealed = create(:post, is_deleted: true)