diff options
author | Matt Jankowski <mjankowski@thoughtbot.com> | 2017-05-07 08:44:28 -0400 |
---|---|---|
committer | Eugen Rochko <eugen@zeonfederated.com> | 2017-05-07 14:44:28 +0200 |
commit | b8ba719f73ec0a2ec7c11b96a740aad8132a5580 (patch) | |
tree | e2ba5151ff488dda1c04520bd2163a1c05421be7 /spec | |
parent | ada8a6cb77af2a142a04319f9064609313f80028 (diff) |
Unblock domain service specs/refactor (#2867)
* Add spec for unblock domain service * Refactor UnblockDomainService
Diffstat (limited to 'spec')
-rw-r--r-- | spec/services/unblock_domain_service_spec.rb | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/spec/services/unblock_domain_service_spec.rb b/spec/services/unblock_domain_service_spec.rb new file mode 100644 index 000000000..c32e5d655 --- /dev/null +++ b/spec/services/unblock_domain_service_spec.rb @@ -0,0 +1,46 @@ +# frozen_string_literal: true + +require 'rails_helper' + +describe UnblockDomainService do + subject { described_class.new } + + describe 'call' do + before do + @silenced = Fabricate(:account, domain: 'example.com', silenced: true) + @suspended = Fabricate(:account, domain: 'example.com', suspended: true) + @domain_block = Fabricate(:domain_block, domain: 'example.com') + end + + context 'without retroactive' do + it 'removes the domain block' do + subject.call(@domain_block, false) + expect_deleted_domain_block + end + end + + context 'with retroactive' do + it 'unsilences accounts and removes block' do + @domain_block.update(severity: :silence) + + subject.call(@domain_block, true) + expect_deleted_domain_block + expect(@silenced.reload.silenced).to be false + expect(@suspended.reload.suspended).to be true + end + + it 'unsuspends accounts and removes block' do + @domain_block.update(severity: :suspend) + + subject.call(@domain_block, true) + expect_deleted_domain_block + expect(@suspended.reload.suspended).to be false + expect(@silenced.reload.silenced).to be true + end + end + end + + def expect_deleted_domain_block + expect { @domain_block.reload }.to raise_error(ActiveRecord::RecordNotFound) + end +end |