|
|
|
@ -57,6 +57,30 @@ describe 'blocking domains through the moderation interface' do
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when suspending a subdomain of an already-silenced domain' do
|
|
|
|
|
it 'presents a confirmation screen before suspending the domain' do
|
|
|
|
|
domain_block = Fabricate(:domain_block, domain: 'example.com', severity: 'silence')
|
|
|
|
|
|
|
|
|
|
visit new_admin_domain_block_path
|
|
|
|
|
|
|
|
|
|
fill_in 'domain_block_domain', with: 'subdomain.example.com'
|
|
|
|
|
select I18n.t('admin.domain_blocks.new.severity.suspend'), from: 'domain_block_severity'
|
|
|
|
|
click_on I18n.t('admin.domain_blocks.new.create')
|
|
|
|
|
|
|
|
|
|
# It presents a confirmation screen
|
|
|
|
|
expect(page).to have_title(I18n.t('admin.domain_blocks.confirm_suspension.title', domain: 'subdomain.example.com'))
|
|
|
|
|
|
|
|
|
|
# Confirming creates the block
|
|
|
|
|
click_on I18n.t('admin.domain_blocks.confirm_suspension.confirm')
|
|
|
|
|
|
|
|
|
|
expect(DomainBlock.where(domain: 'subdomain.example.com', severity: 'suspend')).to exist
|
|
|
|
|
|
|
|
|
|
# And leaves the previous block alone
|
|
|
|
|
expect(domain_block.reload.severity).to eq 'silence'
|
|
|
|
|
expect(domain_block.reload.domain).to eq 'example.com'
|
|
|
|
|
end
|
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
context 'when editing a domain block' do
|
|
|
|
|
it 'presents a confirmation screen before suspending the domain' do
|
|
|
|
|
domain_block = Fabricate(:domain_block, domain: 'example.com', severity: 'silence')
|
|
|
|
|