add spec for Ajax::ModerationController
This commit is contained in:
parent
3e95d5ebeb
commit
0109322610
|
@ -111,7 +111,7 @@ class Ajax::ModerationController < AjaxController
|
|||
params.require :permaban
|
||||
|
||||
reason = params[:reason]
|
||||
target = User.find_by_screen_name(params[:user])
|
||||
target = User.find_by_screen_name!(params[:user])
|
||||
unban = params[:ban] == "0"
|
||||
perma = params[:permaban] == "1"
|
||||
|
||||
|
@ -149,7 +149,7 @@ class Ajax::ModerationController < AjaxController
|
|||
|
||||
status = params[:status] == 'true'
|
||||
|
||||
target_user = User.find_by_screen_name(params[:user])
|
||||
target_user = User.find_by_screen_name!(params[:user])
|
||||
|
||||
@response[:message] = I18n.t('messages.moderation.privilege.nope')
|
||||
return unless %w(moderator admin).include? params[:type].downcase
|
||||
|
|
|
@ -0,0 +1,650 @@
|
|||
# coding: utf-8
|
||||
# frozen_string_literal: true
|
||||
|
||||
require "rails_helper"
|
||||
|
||||
describe Ajax::ModerationController, :ajax_controller, type: :controller do
|
||||
shared_examples "fails when report does not exist" do
|
||||
let(:report_id) { "Burgenland" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "not_found",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
let(:target_user) { FactoryBot.create(:user) }
|
||||
let(:report) do
|
||||
Reports::User.create!(
|
||||
user: user,
|
||||
target_id: target_user.id
|
||||
)
|
||||
end
|
||||
let(:user_role) { :moderator }
|
||||
|
||||
before do
|
||||
user.add_role user_role if user_role
|
||||
sign_in(user)
|
||||
end
|
||||
|
||||
describe "#vote" do
|
||||
let(:params) do
|
||||
{
|
||||
id: report_id,
|
||||
upvote: upvote
|
||||
}
|
||||
end
|
||||
|
||||
subject { post(:vote, params: params) }
|
||||
|
||||
context "when report exists" do
|
||||
let(:report_id) { report.id }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything,
|
||||
"count" => expected_count
|
||||
}
|
||||
end
|
||||
|
||||
context "when upvote is true" do
|
||||
let(:upvote) { "true" }
|
||||
let(:expected_count) { 1 }
|
||||
|
||||
it "creates a moderation vote" do
|
||||
expect { subject }.to(change { ModerationVote.count }.by(1))
|
||||
expect(report.moderation_votes.last.user).to eq(user)
|
||||
expect(report.moderation_votes.last.upvote).to eq(true)
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
|
||||
context "when moderation vote already exists" do
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "fail",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
before { post(:vote, params: params) }
|
||||
|
||||
it "does not create a new moderation vote" do
|
||||
expect { subject }.to_not(change { ModerationVote.count })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
|
||||
context "when upvote is false" do
|
||||
let(:upvote) { "false" }
|
||||
let(:expected_count) { 0 }
|
||||
|
||||
it "creates a moderation vote" do
|
||||
expect { subject }.to(change { ModerationVote.count }.by(1))
|
||||
expect(report.moderation_votes.last.user).to eq(user)
|
||||
expect(report.moderation_votes.last.upvote).to eq(false)
|
||||
end
|
||||
|
||||
context "when moderation vote already exists" do
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "fail",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
before { post(:vote, params: params) }
|
||||
|
||||
it "does not create a new moderation vote" do
|
||||
expect { subject }.to_not(change { ModerationVote.count })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
it_behaves_like "fails when report does not exist" do
|
||||
let(:upvote) { "true" }
|
||||
|
||||
it "does not create a moderation vote" do
|
||||
expect { subject }.to_not(change { ModerationVote.count })
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe "#destroy_vote" do
|
||||
let(:params) do
|
||||
{
|
||||
id: report_id
|
||||
}
|
||||
end
|
||||
|
||||
subject { post(:destroy_vote, params: params) }
|
||||
|
||||
context "when report exists" do
|
||||
let(:report_id) { report.id }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything,
|
||||
"count" => expected_count
|
||||
}
|
||||
end
|
||||
|
||||
context "when the user already voted" do
|
||||
let(:expected_count) { 0 }
|
||||
|
||||
before { post(:vote, params: params.merge("upvote" => true)) }
|
||||
|
||||
it "removes a moderation vote" do
|
||||
expect { subject }.to(change { ModerationVote.count }.by(-1))
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
context "when the user has not voted yet" do
|
||||
let(:expected_count) { 0 }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "fail",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
it "does not create a new moderation vote" do
|
||||
expect { subject }.to_not(change { ModerationVote.count })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
|
||||
it_behaves_like "fails when report does not exist" do
|
||||
it "does not create a moderation vote" do
|
||||
expect { subject }.to_not(change { ModerationVote.count })
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe "#destroy_report" do
|
||||
let(:params) do
|
||||
{
|
||||
id: report_id
|
||||
}
|
||||
end
|
||||
|
||||
subject { post(:destroy_report, params: params) }
|
||||
|
||||
context "when report exists" do
|
||||
let(:report_id) { report.id }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
before { report }
|
||||
|
||||
it "does not actually destroy the report" do
|
||||
expect { subject }.to_not(change { Report.count })
|
||||
end
|
||||
|
||||
it "only marks the report as deleted" do
|
||||
expect { subject }.to(change { report.reload.deleted }.from(false).to(true))
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
it_behaves_like "fails when report does not exist"
|
||||
end
|
||||
|
||||
describe "#create_comment" do
|
||||
let(:params) do
|
||||
{
|
||||
id: report_id,
|
||||
comment: comment
|
||||
}
|
||||
end
|
||||
let(:comment) { "ZEFIX NUAMOI!" }
|
||||
|
||||
subject { post(:create_comment, params: params) }
|
||||
|
||||
context "when report exists" do
|
||||
let(:report_id) { report.id }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything,
|
||||
"render" => anything,
|
||||
"count" => 1
|
||||
}
|
||||
end
|
||||
|
||||
it "creates a moderation comment" do
|
||||
expect { subject }.to(change { ModerationComment.count }.by(1))
|
||||
expect(report.moderation_comments.last.user).to eq(user)
|
||||
expect(report.moderation_comments.last.content).to eq(comment)
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
|
||||
context "when comment is blank" do
|
||||
let(:comment) { "" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "parameter_error",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
it "does not create a moderation comment" do
|
||||
expect { subject }.to_not(change { ModerationComment.count })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
context "when comment is the letter E 621 times" do
|
||||
let(:comment) { "E" * 621 }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "rec_inv",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
it "does not create a moderation comment" do
|
||||
expect { subject }.to_not(change { ModerationComment.count })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
|
||||
it_behaves_like "fails when report does not exist" do
|
||||
it "does not create a moderation comment" do
|
||||
expect { subject }.to_not(change { ModerationComment.count })
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
describe "#destroy_comment" do
|
||||
let(:comment) { ModerationComment.create!(user: comment_user, report: report, content: "sigh") }
|
||||
let(:params) do
|
||||
{
|
||||
comment: comment_id
|
||||
}
|
||||
end
|
||||
|
||||
subject { post(:destroy_comment, params: params) }
|
||||
|
||||
context "when comment exists" do
|
||||
let(:comment_id) { comment.id }
|
||||
|
||||
before { comment }
|
||||
|
||||
context "when comment was made by the current user" do
|
||||
let(:comment_user) { user }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
it "destroys the comment" do
|
||||
expect { subject }.to(change { ModerationComment.count }.by(-1))
|
||||
expect { comment.reload }.to raise_error(ActiveRecord::RecordNotFound)
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
context "when comment was made by someone else" do
|
||||
let(:comment_user) { FactoryBot.create(:user) }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "nopriv",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
it "does not destroy the comment" do
|
||||
expect { subject }.not_to(change { ModerationComment.count })
|
||||
expect { comment.reload }.not_to raise_error
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
|
||||
context "when current user is an administrator" do
|
||||
let(:user_role) { :administrator }
|
||||
|
||||
it "does not destroy the comment" do
|
||||
expect { subject }.not_to(change { ModerationComment.count })
|
||||
expect { comment.reload }.not_to raise_error
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "when comment does not exist" do
|
||||
let(:comment_id) { "Rügenwalder" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "not_found",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
it "does not destroy any comment" do
|
||||
expect { subject }.not_to(change { ModerationComment.count })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
|
||||
describe "#ban" do
|
||||
let(:params) do
|
||||
{
|
||||
user: user_param,
|
||||
ban: ban,
|
||||
permaban: permaban,
|
||||
reason: "just a prank, bro",
|
||||
until: wrongly_formatted_date_ugh
|
||||
}
|
||||
end
|
||||
|
||||
subject { post(:ban, params: params) }
|
||||
|
||||
context "when user exists" do
|
||||
shared_examples "does not ban administrators" do
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "nopriv",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
before { target_user.add_role :administrator }
|
||||
|
||||
it "does not ban the target user" do
|
||||
subject
|
||||
expect(target_user).not_to be_banned
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
let(:user_param) { target_user.screen_name }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
before { target_user }
|
||||
|
||||
context "when ban = 0" do
|
||||
let(:ban) { "0" }
|
||||
let(:wrongly_formatted_date_ugh) { nil }
|
||||
|
||||
"01".each_char do |pb|
|
||||
context "when permaban = #{pb}" do
|
||||
let(:permaban) { pb }
|
||||
|
||||
context "when user is already banned" do
|
||||
before { target_user.ban }
|
||||
|
||||
it "unbans the user" do
|
||||
expect { subject }.to(change { target_user.reload.banned? }.from(true).to(false))
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
context "when user is not yet banned" do
|
||||
it "does not change the status of the ban" do
|
||||
expect { subject }.not_to(change { target_user.reload.banned? })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "when ban = 1" do
|
||||
let(:ban) { "1" }
|
||||
let(:wrongly_formatted_date_ugh) { "4/20/2420 12:00 AM" }
|
||||
|
||||
context "when permaban = 0" do
|
||||
let(:permaban) { "0" }
|
||||
|
||||
it "bans the user until 2420-04-20" do
|
||||
expect { subject }.to(change { target_user.reload.banned? }.from(false).to(true))
|
||||
expect(target_user).not_to be_permanently_banned
|
||||
expect(target_user.ban_reason).to eq("just a prank, bro")
|
||||
expect(target_user.banned_until).to eq(DateTime.strptime(wrongly_formatted_date_ugh, "%m/%d/%Y %I:%M %p"))
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
|
||||
it_behaves_like "does not ban administrators"
|
||||
end
|
||||
|
||||
context "when permaban = 1" do
|
||||
let(:permaban) { "1" }
|
||||
|
||||
it "bans the user for all eternity" do
|
||||
expect { subject }.to(change { target_user.reload.banned? }.from(false).to(true))
|
||||
expect(target_user).to be_permanently_banned
|
||||
expect(target_user.ban_reason).to eq("just a prank, bro")
|
||||
expect(target_user.banned_until).to be_nil
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
|
||||
it_behaves_like "does not ban administrators"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "when user does not exist" do
|
||||
let(:user_param) { "fritz-fantom" }
|
||||
let(:ban) { "1" }
|
||||
let(:permaban) { "1" }
|
||||
let(:wrongly_formatted_date_ugh) { "4/20/2420 12:00 AM" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "not_found",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
|
||||
describe "#privilege" do
|
||||
valid_role_pairs = {
|
||||
moderator: :moderator,
|
||||
admin: :administrator
|
||||
}.freeze
|
||||
|
||||
let(:params) do
|
||||
{
|
||||
user: user_param,
|
||||
type: type,
|
||||
status: status
|
||||
}
|
||||
end
|
||||
|
||||
subject { post(:privilege, params: params) }
|
||||
|
||||
context "when user exists" do
|
||||
let(:user_param) { target_user.screen_name }
|
||||
before { target_user }
|
||||
|
||||
{
|
||||
nil => "has no extra roles",
|
||||
:moderator => "is a moderator"
|
||||
}.each do |u_role, context_desc|
|
||||
context "when the current user #{context_desc}" do
|
||||
let(:user_role) { u_role }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "nopriv",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
valid_role_pairs.each do |type, role_name|
|
||||
context "when type is #{type}" do
|
||||
let(:type) { type }
|
||||
|
||||
context "when status is true" do
|
||||
let(:status) { "true" }
|
||||
|
||||
it "does not modify the roles on the target user" do
|
||||
expect { subject }.not_to(change { target_user.reload.roles.to_a })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
context "when status is false" do
|
||||
let(:status) { "true" }
|
||||
|
||||
before { target_user.add_role role_name }
|
||||
|
||||
it "does not modify the roles on the target user" do
|
||||
expect { subject }.not_to(change { target_user.reload.roles.to_a })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "when the current user is an administrator" do
|
||||
let(:user_role) { :administrator }
|
||||
|
||||
valid_role_pairs.each do |type, role_name|
|
||||
context "when type is #{type}" do
|
||||
let(:type) { type }
|
||||
|
||||
context "when status is true" do
|
||||
let(:status) { "true" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything,
|
||||
"checked" => true
|
||||
}
|
||||
end
|
||||
|
||||
it "adds the #{role_name} role to the target user" do
|
||||
expect { subject }.to(change { target_user.roles.reload.to_a })
|
||||
expect(target_user).to have_role(role_name)
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
|
||||
context "when status is false" do
|
||||
let(:status) { "false" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => true,
|
||||
"status" => "okay",
|
||||
"message" => anything,
|
||||
"checked" => false
|
||||
}
|
||||
end
|
||||
|
||||
before { target_user.add_role role_name }
|
||||
|
||||
it "removes the #{role_name} role from the target user" do
|
||||
expect { subject }.to(change { target_user.reload.roles.to_a })
|
||||
expect(target_user).not_to have_role(role_name)
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "when type is some bogus value" do
|
||||
let(:type) { "some bogus value" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "err",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
%w[true false].each do |s|
|
||||
context "when status is #{s}" do
|
||||
let(:status) { s }
|
||||
|
||||
it "does not modify the roles on the target user" do
|
||||
expect { subject }.not_to(change { target_user.reload.roles.to_a })
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
context "when user does not exist" do
|
||||
let(:user_param) { "fritz-fantom" }
|
||||
let(:type) { "admin" }
|
||||
let(:status) { "true" }
|
||||
let(:expected_response) do
|
||||
{
|
||||
"success" => false,
|
||||
"status" => "not_found",
|
||||
"message" => anything
|
||||
}
|
||||
end
|
||||
|
||||
include_examples "returns the expected response"
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue