Retrospring/spec/controllers/ajax/moderation_controller_spec.rb

652 lines
17 KiB
Ruby
Raw Normal View History

# 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,
reason: "just a prank, bro",
2021-12-29 15:20:09 -08:00
duration: duration,
duration_unit: duration_unit,
}
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" }
"01".each_char do |pb|
context "when permaban = #{pb}" do
2021-12-30 04:05:52 -08:00
let(:duration) { pb == '0' ? 3 : nil }
let(:duration_unit) { pb == '0' ? 'hours' : nil }
context "when user is already banned" do
2021-12-29 15:20:09 -08:00
before { target_user.ban(nil) }
it "unbans the user" do
2021-12-30 12:06:21 -08:00
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" }
context "when permaban = 0" do
2021-12-30 12:06:21 -08:00
let(:duration) { 3 }
let(:duration_unit) { 'hours' }
2021-12-29 15:20:09 -08:00
it "bans the user for 3 hours" do
Timecop.freeze do
2021-12-30 12:06:21 -08:00
expect { subject }.to change { target_user.reload.banned? }.from(false).to(true)
2021-12-29 15:20:09 -08:00
expect(target_user.bans.current.first.reason).to eq("just a prank, bro")
2021-12-30 04:05:52 -08:00
expect(target_user.bans.current.first.expires_at.to_i).to eq((Time.now.utc + 3.hours).to_i)
2021-12-29 15:20:09 -08:00
end
end
include_examples "returns the expected response"
it_behaves_like "does not ban administrators"
end
context "when permaban = 1" do
2021-12-29 15:20:09 -08:00
let(:duration) { nil }
let(:duration_unit) { nil }
it "bans the user for all eternity" do
2021-12-29 15:20:09 -08:00
expect { subject }.to change { target_user.reload.banned? }.from(false).to(true)
expect(target_user.bans.current.first.reason).to eq("just a prank, bro")
expect(target_user.bans.current.first.expires_at).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" }
2021-12-29 15:20:09 -08:00
let(:duration) { nil }
let(:duration_unit) { nil }
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