about summary refs log tree commit diff
path: root/spec/policies/ip_block_policy_spec.rb
diff options
context:
space:
mode:
authorMatt Jankowski <matt@jankowski.online>2023-03-04 10:57:22 -0500
committerGitHub <noreply@github.com>2023-03-04 16:57:22 +0100
commit00eb2269b691b90f361dd03454cf823934389282 (patch)
tree9570ca0e075a4b7ed3b8db80746a5a19b5db37b2 /spec/policies/ip_block_policy_spec.rb
parent6a57c423169d76301078948821c1da916dcdf75b (diff)
Policies specs (#23924)
Diffstat (limited to 'spec/policies/ip_block_policy_spec.rb')
-rw-r--r--spec/policies/ip_block_policy_spec.rb24
1 files changed, 24 insertions, 0 deletions
diff --git a/spec/policies/ip_block_policy_spec.rb b/spec/policies/ip_block_policy_spec.rb
new file mode 100644
index 000000000..3cfa85863
--- /dev/null
+++ b/spec/policies/ip_block_policy_spec.rb
@@ -0,0 +1,24 @@
+# frozen_string_literal: true
+
+require 'rails_helper'
+require 'pundit/rspec'
+
+describe IpBlockPolicy do
+  let(:policy) { described_class }
+  let(:admin)   { Fabricate(:user, role: UserRole.find_by(name: 'Admin')).account }
+  let(:john)    { Fabricate(:account) }
+
+  permissions :index?, :show?, :create?, :update?, :destroy? do
+    context 'with an admin' do
+      it 'permits' do
+        expect(policy).to permit(admin, Tag)
+      end
+    end
+
+    context 'with a non-admin' do
+      it 'denies' do
+        expect(policy).to_not permit(john, Tag)
+      end
+    end
+  end
+end