2023-02-22 11:55:31 +11:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-12-13 23:42:10 +11:00
|
|
|
require 'rails_helper'
|
|
|
|
|
2023-05-04 13:49:53 +10:00
|
|
|
RSpec.describe Admin::DomainBlocksController do
|
2017-04-28 23:12:37 +10:00
|
|
|
render_views
|
|
|
|
|
2016-12-13 23:42:10 +11:00
|
|
|
before do
|
2022-07-05 10:41:40 +10:00
|
|
|
sign_in Fabricate(:user, role: UserRole.find_by(name: 'Admin')), scope: :user
|
2016-12-13 23:42:10 +11:00
|
|
|
end
|
|
|
|
|
2017-04-30 08:25:38 +10:00
|
|
|
describe 'GET #new' do
|
2017-06-26 05:42:36 +10:00
|
|
|
it 'assigns a new domain block' do
|
2017-04-30 08:25:38 +10:00
|
|
|
get :new
|
|
|
|
|
2017-06-26 05:42:36 +10:00
|
|
|
expect(assigns(:domain_block)).to be_instance_of(DomainBlock)
|
2018-04-22 05:35:07 +10:00
|
|
|
expect(response).to have_http_status(200)
|
2017-04-30 08:25:38 +10:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-11-17 21:05:09 +11:00
|
|
|
describe 'POST #batch' do
|
|
|
|
it 'blocks the domains when succeeded to save' do
|
|
|
|
allow(DomainBlockWorker).to receive(:perform_async).and_return(true)
|
|
|
|
|
|
|
|
post :batch, params: {
|
|
|
|
save: '',
|
|
|
|
form_domain_block_batch: {
|
|
|
|
domain_blocks_attributes: {
|
|
|
|
'0' => { enabled: '1', domain: 'example.com', severity: 'silence' },
|
|
|
|
'1' => { enabled: '0', domain: 'mastodon.social', severity: 'suspend' },
|
2023-02-19 01:33:41 +11:00
|
|
|
'2' => { enabled: '1', domain: 'mastodon.online', severity: 'suspend' },
|
|
|
|
},
|
|
|
|
},
|
2022-11-17 21:05:09 +11:00
|
|
|
}
|
|
|
|
|
|
|
|
expect(DomainBlockWorker).to have_received(:perform_async).exactly(2).times
|
|
|
|
expect(flash[:notice]).to eq I18n.t('admin.domain_blocks.created_msg')
|
|
|
|
expect(response).to redirect_to(admin_instances_path(limited: '1'))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-04-30 08:25:38 +10:00
|
|
|
describe 'POST #create' do
|
2023-06-01 17:37:38 +10:00
|
|
|
before do
|
2017-04-30 08:25:38 +10:00
|
|
|
allow(DomainBlockWorker).to receive(:perform_async).and_return(true)
|
2023-06-01 17:37:38 +10:00
|
|
|
end
|
2017-06-26 05:42:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
context 'with "silence" severity and no conflict' do
|
|
|
|
before do
|
|
|
|
post :create, params: { domain_block: { domain: 'example.com', severity: 'silence' } }
|
|
|
|
end
|
2017-04-30 08:25:38 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
it 'records a block' do
|
|
|
|
expect(DomainBlock.exists?(domain: 'example.com', severity: 'silence')).to be true
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'calls DomainBlockWorker' do
|
|
|
|
expect(DomainBlockWorker).to have_received(:perform_async)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'redirects with a success message' do
|
|
|
|
expect(flash[:notice]).to eq I18n.t('admin.domain_blocks.created_msg')
|
|
|
|
expect(response).to redirect_to(admin_instances_path(limited: '1'))
|
|
|
|
end
|
2017-04-30 08:25:38 +10:00
|
|
|
end
|
2017-06-26 05:42:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
context 'when the new domain block conflicts with an existing one' do
|
|
|
|
before do
|
|
|
|
Fabricate(:domain_block, domain: 'example.com', severity: 'suspend')
|
|
|
|
post :create, params: { domain_block: { domain: 'example.com', severity: 'silence' } }
|
|
|
|
end
|
2017-06-26 05:42:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
it 'does not record a block' do
|
|
|
|
expect(DomainBlock.exists?(domain: 'example.com', severity: 'silence')).to be false
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not call DomainBlockWorker' do
|
|
|
|
expect(DomainBlockWorker).to_not have_received(:perform_async)
|
|
|
|
end
|
2017-06-26 05:42:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
it 'renders new' do
|
|
|
|
expect(response).to render_template :new
|
|
|
|
end
|
2017-06-26 05:42:36 +10:00
|
|
|
end
|
2019-05-04 04:36:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
context 'with "suspend" severity and no conflict' do
|
|
|
|
context 'without a confirmation' do
|
|
|
|
before do
|
|
|
|
post :create, params: { domain_block: { domain: 'example.com', severity: 'suspend', reject_media: true, reject_reports: true } }
|
|
|
|
end
|
2019-05-04 04:36:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
it 'does not record a block' do
|
|
|
|
expect(DomainBlock.exists?(domain: 'example.com', severity: 'suspend')).to be false
|
|
|
|
end
|
2019-05-04 04:36:36 +10:00
|
|
|
|
2023-06-01 17:37:38 +10:00
|
|
|
it 'does not call DomainBlockWorker' do
|
|
|
|
expect(DomainBlockWorker).to_not have_received(:perform_async)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders confirm_suspension' do
|
|
|
|
expect(response).to render_template :confirm_suspension
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a confirmation' do
|
|
|
|
before do
|
|
|
|
post :create, params: { :domain_block => { domain: 'example.com', severity: 'suspend', reject_media: true, reject_reports: true }, 'confirm' => '' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'records a block' do
|
|
|
|
expect(DomainBlock.exists?(domain: 'example.com', severity: 'suspend')).to be true
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'calls DomainBlockWorker' do
|
|
|
|
expect(DomainBlockWorker).to have_received(:perform_async)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'redirects with a success message' do
|
|
|
|
expect(flash[:notice]).to eq I18n.t('admin.domain_blocks.created_msg')
|
|
|
|
expect(response).to redirect_to(admin_instances_path(limited: '1'))
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when upgrading an existing block' do
|
|
|
|
before do
|
|
|
|
Fabricate(:domain_block, domain: 'example.com', severity: 'silence')
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'without a confirmation' do
|
|
|
|
before do
|
|
|
|
post :create, params: { domain_block: { domain: 'example.com', severity: 'suspend', reject_media: true, reject_reports: true } }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not record a block' do
|
|
|
|
expect(DomainBlock.exists?(domain: 'example.com', severity: 'suspend')).to be false
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not call DomainBlockWorker' do
|
|
|
|
expect(DomainBlockWorker).to_not have_received(:perform_async)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'renders confirm_suspension' do
|
|
|
|
expect(response).to render_template :confirm_suspension
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with a confirmation' do
|
|
|
|
before do
|
|
|
|
post :create, params: { :domain_block => { domain: 'example.com', severity: 'suspend', reject_media: true, reject_reports: true }, 'confirm' => '' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'updates the record' do
|
|
|
|
expect(DomainBlock.exists?(domain: 'example.com', severity: 'suspend')).to be true
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'calls DomainBlockWorker' do
|
|
|
|
expect(DomainBlockWorker).to have_received(:perform_async)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'redirects with a success message' do
|
|
|
|
expect(flash[:notice]).to eq I18n.t('admin.domain_blocks.created_msg')
|
|
|
|
expect(response).to redirect_to(admin_instances_path(limited: '1'))
|
|
|
|
end
|
|
|
|
end
|
2019-05-04 04:36:36 +10:00
|
|
|
end
|
2017-04-30 08:25:38 +10:00
|
|
|
end
|
|
|
|
|
2023-10-17 02:20:28 +11:00
|
|
|
describe 'GET #edit' do
|
|
|
|
let(:domain_block) { Fabricate(:domain_block) }
|
|
|
|
|
|
|
|
it 'returns http success' do
|
|
|
|
get :edit, params: { id: domain_block.id }
|
|
|
|
|
|
|
|
expect(assigns(:domain_block)).to be_instance_of(DomainBlock)
|
|
|
|
expect(response).to have_http_status(200)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2022-12-16 03:45:02 +11:00
|
|
|
describe 'PUT #update' do
|
2023-07-12 17:49:33 +10:00
|
|
|
subject do
|
2023-06-01 17:37:38 +10:00
|
|
|
post :update, params: { :id => domain_block.id, :domain_block => { domain: 'example.com', severity: new_severity }, 'confirm' => '' }
|
2023-02-20 13:17:41 +11:00
|
|
|
end
|
2023-07-12 17:49:33 +10:00
|
|
|
|
|
|
|
let!(:remote_account) { Fabricate(:account, domain: 'example.com') }
|
2023-02-20 13:17:41 +11:00
|
|
|
let(:domain_block) { Fabricate(:domain_block, domain: 'example.com', severity: original_severity) }
|
2022-12-16 03:45:02 +11:00
|
|
|
|
|
|
|
before do
|
|
|
|
BlockDomainService.new.call(domain_block)
|
|
|
|
end
|
|
|
|
|
2023-05-04 13:49:08 +10:00
|
|
|
context 'when downgrading a domain suspension to silence' do
|
2022-12-16 03:45:02 +11:00
|
|
|
let(:original_severity) { 'suspend' }
|
|
|
|
let(:new_severity) { 'silence' }
|
|
|
|
|
2023-12-04 20:02:40 +11:00
|
|
|
it 'changes the block severity, suspensions, and silences' do
|
|
|
|
expect { subject }
|
|
|
|
.to change_severity('suspend', 'silence')
|
|
|
|
.and change_suspended(true, false)
|
|
|
|
.and change_silenced(false, true)
|
2022-12-16 03:45:02 +11:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2023-05-04 13:49:08 +10:00
|
|
|
context 'when upgrading a domain silence to suspend' do
|
2022-12-16 03:45:02 +11:00
|
|
|
let(:original_severity) { 'silence' }
|
|
|
|
let(:new_severity) { 'suspend' }
|
|
|
|
|
2023-12-04 20:02:40 +11:00
|
|
|
it 'changes the block severity, silences, and suspensions' do
|
|
|
|
expect { subject }
|
|
|
|
.to change_severity('silence', 'suspend')
|
|
|
|
.and change_silenced(true, false)
|
|
|
|
.and change_suspended(false, true)
|
2022-12-16 03:45:02 +11:00
|
|
|
end
|
2023-12-04 20:02:40 +11:00
|
|
|
end
|
2022-12-16 03:45:02 +11:00
|
|
|
|
2023-12-04 20:02:40 +11:00
|
|
|
private
|
2022-12-16 03:45:02 +11:00
|
|
|
|
2023-12-04 20:02:40 +11:00
|
|
|
def change_severity(from, to)
|
|
|
|
change { domain_block.reload.severity }.from(from).to(to)
|
|
|
|
end
|
|
|
|
|
|
|
|
def change_silenced(from, to)
|
|
|
|
change { remote_account.reload.silenced? }.from(from).to(to)
|
|
|
|
end
|
|
|
|
|
|
|
|
def change_suspended(from, to)
|
|
|
|
change { remote_account.reload.suspended? }.from(from).to(to)
|
2022-12-16 03:45:02 +11:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2017-04-30 08:25:38 +10:00
|
|
|
describe 'DELETE #destroy' do
|
|
|
|
it 'unblocks the domain' do
|
2023-06-22 22:55:22 +10:00
|
|
|
service = instance_double(UnblockDomainService, call: true)
|
2017-04-30 08:25:38 +10:00
|
|
|
allow(UnblockDomainService).to receive(:new).and_return(service)
|
|
|
|
domain_block = Fabricate(:domain_block)
|
2019-05-15 03:05:02 +10:00
|
|
|
delete :destroy, params: { id: domain_block.id }
|
2017-04-30 08:25:38 +10:00
|
|
|
|
2019-05-15 03:05:02 +10:00
|
|
|
expect(service).to have_received(:call).with(domain_block)
|
2017-06-26 05:42:36 +10:00
|
|
|
expect(flash[:notice]).to eq I18n.t('admin.domain_blocks.destroyed_msg')
|
2019-01-08 23:39:49 +11:00
|
|
|
expect(response).to redirect_to(admin_instances_path(limited: '1'))
|
2017-04-30 08:25:38 +10:00
|
|
|
end
|
|
|
|
end
|
2016-12-13 23:42:10 +11:00
|
|
|
end
|