Files
danbooru/test/functional/post_disapprovals_controller_test.rb
2022-04-11 21:05:44 +02:00

113 lines
4.4 KiB
Ruby

require 'test_helper'
class PostDisapprovalsControllerTest < ActionDispatch::IntegrationTest
context "The post disapprovals controller" do
setup do
@approver = create(:approver, name: "eiki")
@post = create(:post, tag_string: "touhou", is_pending: true, uploader: build(:user, name: "marisa", created_at: 2.weeks.ago))
end
context "create action" do
should "render" do
assert_difference("PostDisapproval.count", 1) do
post_auth post_disapprovals_path, @approver, params: { post_disapproval: { post_id: @post.id, reason: "breaks_rules" }, format: "js" }
assert_response :success
end
end
should "render for json" do
assert_difference("PostDisapproval.count", 1) do
post_auth post_disapprovals_path, @approver, params: { post_disapproval: { post_id: @post.id, reason: "breaks_rules" }, format: "json" }
assert_response :success
end
end
should "not allow non-approvers to create disapprovals" do
assert_difference("PostDisapproval.count", 0) do
post_auth post_disapprovals_path, create(:user), params: { post_disapproval: { post_id: @post.id, reason: "breaks_rules" }, format: "json" }
assert_response 403
end
end
should "not allow disapproving active posts" do
assert_difference("PostDisapproval.count", 0) do
@post.update!(is_pending: false)
post_auth post_disapprovals_path, @approver, params: { post_disapproval: { post_id: @post.id, reason: "breaks_rules" }, format: "js" }
assert_response :success
end
end
end
context "index action" do
setup do
@post_disapproval = create(:post_disapproval, post: @post)
@user_disapproval = create(:post_disapproval, user: @approver)
@unrelated_disapproval = create(:post_disapproval, message: "bad")
end
should "render" do
get post_disapprovals_path
assert_response :success
end
should respond_to_search({}).with { [@unrelated_disapproval, @user_disapproval, @post_disapproval] }
should respond_to_search(message: "bad").with { @unrelated_disapproval }
context "using includes" do
should respond_to_search(post_tags_match: "touhou").with { @post_disapproval }
should respond_to_search(post: {uploader_name: "marisa"}).with { @post_disapproval }
should respond_to_search(user_name: "eiki").with { [] }
end
should "allow mods to see disapprover names" do
get_auth post_disapprovals_path, create(:mod_user)
assert_response :success
assert_select "tr#post-disapproval-#{@post_disapproval.id} .created-column a.user-post-approver", true
end
should "not allow non-mods to see disapprover names" do
get post_disapprovals_path
assert_response :success
assert_select "tr#post-disapproval-#{@post_disapproval.id} .created-column a.user-post-approver", false
end
context "when a non-mod searches by disapprover name" do
should respond_to_search(user_name: "eiki").with { [] }
end
context "when a mod searches by disapprover name" do
setup { CurrentUser.user = create(:mod_user) }
should respond_to_search(user_name: "eiki").with { @user_disapproval }
end
context "when a disapprover searches by their own name" do
setup { CurrentUser.user = @approver }
should respond_to_search(user_name: "eiki").with { @user_disapproval }
end
end
context "update action" do
setup do
@post = create(:post, is_pending: true)
@approver = create(:approver, name: "alice-san")
@another_approver = create(:approver, name: "bob-kun")
@post_disapproval = create(:post_disapproval, post: @post, user: @approver, reason: "poor_quality")
end
should "allow editing of disapprovals" do
put_auth post_disapproval_path(@post_disapproval), @approver, params: {post_disapproval: {reason: "breaks_rules"}}
assert_redirected_to(@post)
assert_equal("breaks_rules", @post_disapproval.reload.reason)
end
should "not allow editing by another user" do
put_auth post_disapproval_path(@post_disapproval), @another_approver, params: {post_disapproval: {reason: "disinterest"}}
assert_response 403
assert_equal("poor_quality", @post_disapproval.reload.reason)
end
end
end
end