about summary refs log tree commit diff
path: root/spec/services/unblock_domain_service_spec.rb
diff options
context:
space:
mode:
authorMatt Jankowski <mjankowski@thoughtbot.com>2017-05-07 08:44:28 -0400
committerEugen Rochko <eugen@zeonfederated.com>2017-05-07 14:44:28 +0200
commitb8ba719f73ec0a2ec7c11b96a740aad8132a5580 (patch)
treee2ba5151ff488dda1c04520bd2163a1c05421be7 /spec/services/unblock_domain_service_spec.rb
parentada8a6cb77af2a142a04319f9064609313f80028 (diff)
Unblock domain service specs/refactor (#2867)
* Add spec for unblock domain service

* Refactor UnblockDomainService
Diffstat (limited to 'spec/services/unblock_domain_service_spec.rb')
-rw-r--r--spec/services/unblock_domain_service_spec.rb46
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