gitlab-org--gitlab-foss/spec/controllers/abuse_reports_controller_spec.rb

76 lines
1.9 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe AbuseReportsController do
let(:reporter) { create(:user) }
let(:user) { create(:user) }
let(:attrs) do
attributes_for(:abuse_report) do |hash|
hash[:user_id] = user.id
end
end
before do
sign_in(reporter)
end
describe 'GET new' do
context 'when the user has already been deleted' do
it 'redirects the reporter to root_path' do
user_id = user.id
user.destroy
get :new, params: { user_id: user_id }
expect(response).to redirect_to root_path
expect(flash[:alert]).to eq(_('Cannot create the abuse report. The user has been deleted.'))
end
end
context 'when the user has already been blocked' do
it 'redirects the reporter to the user\'s profile' do
user.block
get :new, params: { user_id: user.id }
expect(response).to redirect_to user
expect(flash[:alert]).to eq(_('Cannot create the abuse report. This user has been blocked.'))
end
end
end
describe 'POST create' do
context 'with valid attributes' do
it 'saves the abuse report' do
expect do
post :create, params: { abuse_report: attrs }
end.to change { AbuseReport.count }.by(1)
2015-10-18 05:58:53 -04:00
end
it 'calls notify' do
expect_next_instance_of(AbuseReport) do |instance|
expect(instance).to receive(:notify)
end
2015-11-30 09:12:31 -05:00
post :create, params: { abuse_report: attrs }
2015-11-30 09:12:31 -05:00
end
it 'redirects back to the reported user' do
post :create, params: { abuse_report: attrs }
2015-10-18 05:58:53 -04:00
expect(response).to redirect_to user
2015-10-18 05:58:53 -04:00
end
end
2015-10-18 05:58:53 -04:00
context 'with invalid attributes' do
it 'renders new' do
attrs.delete(:user_id)
post :create, params: { abuse_report: attrs }
2015-10-18 05:58:53 -04:00
expect(response).to render_template(:new)
2015-10-18 05:58:53 -04:00
end
end
end
2015-10-18 05:58:53 -04:00
end