2020-05-01 22:41:26 +02:00
# 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-30 00:20:09 +01:00
duration : duration ,
duration_unit : duration_unit ,
2020-05-01 22:41:26 +02:00
}
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 13:05:52 +01:00
let ( :duration ) { pb == '0' ? 3 : nil }
let ( :duration_unit ) { pb == '0' ? 'hours' : nil }
2020-05-01 22:41:26 +02:00
context " when user is already banned " do
2022-06-26 11:00:09 +02:00
before { target_user . ban }
2020-05-01 22:41:26 +02:00
it " unbans the user " do
2022-06-26 11:00:09 +02:00
expect { subject } . to change { target_user . reload . banned? } . from ( true ) . to ( false )
2020-05-01 22:41:26 +02:00
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 21:06:21 +01:00
let ( :duration ) { 3 }
let ( :duration_unit ) { 'hours' }
2020-05-01 22:41:26 +02:00
2021-12-30 00:20:09 +01:00
it " bans the user for 3 hours " do
Timecop . freeze do
2021-12-30 21:06:21 +01:00
expect { subject } . to change { target_user . reload . banned? } . from ( false ) . to ( true )
2021-12-30 00:20:09 +01:00
expect ( target_user . bans . current . first . reason ) . to eq ( " just a prank, bro " )
2021-12-30 13:05:52 +01:00
expect ( target_user . bans . current . first . expires_at . to_i ) . to eq ( ( Time . now . utc + 3 . hours ) . to_i )
2021-12-30 00:20:09 +01:00
end
2020-05-01 22:41:26 +02:00
end
include_examples " returns the expected response "
it_behaves_like " does not ban administrators "
end
context " when permaban = 1 " do
2021-12-30 00:20:09 +01:00
let ( :duration ) { nil }
let ( :duration_unit ) { nil }
2020-05-01 22:41:26 +02:00
it " bans the user for all eternity " do
2021-12-30 00:20:09 +01: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
2020-05-01 22:41:26 +02:00
end
include_examples " returns the expected response "
it_behaves_like " does not ban administrators "
end
end
end
2021-12-30 21:06:36 +01:00
context " when reason = Spam " do
let ( :params ) do
{
user : target_user . screen_name ,
ban : " 1 " ,
reason : " Spam " ,
duration : nil ,
duration_unit : nil ,
}
end
it " empties the user's profile " do
user . profile . display_name = " Veggietales Facts "
user . profile . description = " Are you a fan of Veggietales? Want to expand your veggie knowledge? Here at Veggietales Facts, we tweet trivia for fans like you. "
user . profile . location = " Hell "
user . profile . website = " https://twitter.com/veggiefact "
expect { subject } . to change { target_user . reload . banned? } . from ( false ) . to ( true )
expect ( target_user . bans . current . first . reason ) . to eq ( " Spam " )
expect ( target_user . profile . display_name ) . to be_nil
expect ( target_user . profile . description ) . to be_empty
expect ( target_user . profile . location ) . to be_empty
expect ( target_user . profile . website ) . to be_empty
end
end
2020-05-01 22:41:26 +02:00
context " when user does not exist " do
let ( :user_param ) { " fritz-fantom " }
let ( :ban ) { " 1 " }
2021-12-30 00:20:09 +01:00
let ( :duration ) { nil }
let ( :duration_unit ) { nil }
2020-05-01 22:41:26 +02:00
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