Files
danbooru/test/unit/post_approval_test.rb
evazion acc4a21687 posts: allow admins to approve the same post twice.
This is so admins can overrule flags and always have the final say in whether a
post is approved, even in the event of coordinated or sockpuppet flagging.

Fixes #4980: Way to mark flags as invalid for admins
2022-06-05 15:51:58 -05:00

106 lines
3.9 KiB
Ruby

require 'test_helper'
class PostApprovalTest < ActiveSupport::TestCase
context "Post approvals:" do
setup do
@user = create(:user, created_at: 2.weeks.ago)
@post = create(:post, uploader: @user, is_pending: true)
@approver = create(:user, can_approve_posts: true)
end
context "a pending post" do
context "that is approved" do
should "create a postapproval record" do
create(:post_approval, post: @post, user: @approver)
assert_equal(1, @post.approvals.count)
assert_equal(@approver, @post.approver)
assert_equal(false, @post.reload.is_pending?)
assert_equal(true, @post.reload.is_active?)
end
should "prevent an approver from approving the same post twice" do
@approval1 = create(:post_approval, post: @post, user: @approver)
@approval2 = build(:post_approval, post: @post, user: @approver)
assert_equal(false, @approval2.valid?)
assert_equal(["You have previously approved this post and cannot approve it again"], @approval2.errors[:base])
end
should "allow an admin to approve the same post twice" do
@approver = create(:admin_user)
create(:post_approval, post: @post, user: @approver)
assert_equal(1, @post.approvals.count)
assert_equal(@approver, @post.approver)
assert_equal(false, @post.reload.is_pending?)
assert_equal(true, @post.reload.is_active?)
flag = create(:post_flag, post: @post, creator: create(:user))
assert_equal(true, @post.reload.is_flagged?)
assert_equal(false, @post.reload.is_active?)
assert_equal("pending", flag.reload.status)
create(:post_approval, post: @post, user: @approver)
assert_equal(2, @post.approvals.count)
assert_equal(@approver, @post.approver)
assert_equal(false, @post.reload.is_flagged?)
assert_equal(true, @post.reload.is_active?)
assert_equal("rejected", flag.reload.status)
end
end
end
context "a deleted post" do
setup do
create(:post_approval, post: @post, user: @approver)
@post.delete!("Unapproved in three days", user: User.system)
end
context "that is undeleted by a different approver" do
should "be updated with the new approver" do
@new_approver = create(:user)
create(:post_approval, post: @post, user: @new_approver)
assert_equal(2, @post.approvals.count)
assert_equal(@new_approver, @post.approver)
assert_equal(false, @post.reload.is_deleted?)
assert_equal(true, @post.reload.is_active?)
assert_equal("post_undelete", ModAction.last.category)
assert_equal("undeleted post ##{@post.id}", ModAction.last.description)
end
end
context "that is undeleted by the same approver" do
should "not be permitted" do
@approval = build(:post_approval, post: @post, user: @approver)
assert_equal(false, @approval.valid?)
assert_equal(["You have previously approved this post and cannot approve it again"], @approval.errors.full_messages)
end
end
context "that is undeleted by the uploader" do
should "not be permitted" do
@approval = build(:post_approval, post: @post, user: @post.uploader)
assert_equal(false, @approval.valid?)
assert_equal(["You cannot approve a post you uploaded"], @approval.errors.full_messages)
end
end
end
context "#search method" do
should "work" do
CurrentUser.scoped(@approver) do
@post.update!(tag_string: "touhou")
@approval = create(:post_approval, post: @post, user: @approver)
@approvals = PostApproval.search(user_name: @approver.name, post_tags_match: "touhou", post_id: @post.id)
assert_equal([@approval.id], @approvals.map(&:id))
end
end
end
end
end