You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
133 lines
3.9 KiB
133 lines
3.9 KiB
require 'rails_helper' |
|
|
|
describe Admin::ReportsController do |
|
render_views |
|
|
|
let(:user) { Fabricate(:user, admin: true) } |
|
before do |
|
sign_in user, scope: :user |
|
end |
|
|
|
describe 'GET #index' do |
|
it 'returns http success with no filters' do |
|
specified = Fabricate(:report, action_taken: false) |
|
Fabricate(:report, action_taken: true) |
|
|
|
get :index |
|
|
|
reports = assigns(:reports).to_a |
|
expect(reports.size).to eq 1 |
|
expect(reports[0]).to eq specified |
|
expect(response).to have_http_status(:success) |
|
end |
|
|
|
it 'returns http success with resolved filter' do |
|
specified = Fabricate(:report, action_taken: true) |
|
Fabricate(:report, action_taken: false) |
|
|
|
get :index, params: { resolved: 1 } |
|
|
|
reports = assigns(:reports).to_a |
|
expect(reports.size).to eq 1 |
|
expect(reports[0]).to eq specified |
|
|
|
expect(response).to have_http_status(:success) |
|
end |
|
end |
|
|
|
describe 'GET #show' do |
|
it 'renders report' do |
|
report = Fabricate(:report) |
|
|
|
get :show, params: { id: report } |
|
|
|
expect(assigns(:report)).to eq report |
|
expect(response).to have_http_status(:success) |
|
end |
|
end |
|
|
|
describe 'PUT #update' do |
|
describe 'with an unknown outcome' do |
|
it 'rejects the change' do |
|
report = Fabricate(:report) |
|
put :update, params: { id: report, outcome: 'unknown' } |
|
|
|
expect(response).to have_http_status(:missing) |
|
end |
|
end |
|
|
|
describe 'with an outcome of `resolve`' do |
|
it 'resolves the report' do |
|
report = Fabricate(:report) |
|
|
|
put :update, params: { id: report, outcome: 'resolve' } |
|
expect(response).to redirect_to(admin_reports_path) |
|
report.reload |
|
expect(report.action_taken_by_account).to eq user.account |
|
expect(report.action_taken).to eq true |
|
end |
|
end |
|
|
|
describe 'with an outcome of `suspend`' do |
|
it 'suspends the reported account' do |
|
report = Fabricate(:report) |
|
allow(Admin::SuspensionWorker).to receive(:perform_async) |
|
|
|
put :update, params: { id: report, outcome: 'suspend' } |
|
expect(response).to redirect_to(admin_reports_path) |
|
report.reload |
|
expect(report.action_taken_by_account).to eq user.account |
|
expect(report.action_taken).to eq true |
|
expect(Admin::SuspensionWorker). |
|
to have_received(:perform_async).with(report.target_account_id) |
|
end |
|
end |
|
|
|
describe 'with an outsome of `silence`' do |
|
it 'silences the reported account' do |
|
report = Fabricate(:report) |
|
|
|
put :update, params: { id: report, outcome: 'silence' } |
|
expect(response).to redirect_to(admin_reports_path) |
|
report.reload |
|
expect(report.action_taken_by_account).to eq user.account |
|
expect(report.action_taken).to eq true |
|
expect(report.target_account).to be_silenced |
|
end |
|
end |
|
|
|
describe 'with an outsome of `reopen`' do |
|
it 'reopens the report' do |
|
report = Fabricate(:report) |
|
|
|
put :update, params: { id: report, outcome: 'reopen' } |
|
expect(response).to redirect_to(admin_report_path(report)) |
|
report.reload |
|
expect(report.action_taken_by_account).to eq nil |
|
expect(report.action_taken).to eq false |
|
end |
|
end |
|
|
|
describe 'with an outsome of `assign_to_self`' do |
|
it 'reopens the report' do |
|
report = Fabricate(:report) |
|
|
|
put :update, params: { id: report, outcome: 'assign_to_self' } |
|
expect(response).to redirect_to(admin_report_path(report)) |
|
report.reload |
|
expect(report.assigned_account).to eq user.account |
|
end |
|
end |
|
|
|
describe 'with an outsome of `unassign`' do |
|
it 'reopens the report' do |
|
report = Fabricate(:report) |
|
|
|
put :update, params: { id: report, outcome: 'unassign' } |
|
expect(response).to redirect_to(admin_report_path(report)) |
|
report.reload |
|
expect(report.assigned_account).to eq nil |
|
end |
|
end |
|
end |
|
end
|
|
|