Files
codeocean/spec/policies/internal_user_policy_spec.rb
2022-09-22 19:24:26 +02:00

38 lines
1.1 KiB
Ruby

# frozen_string_literal: true
require 'rails_helper'
describe InternalUserPolicy do
subject(:policy) { described_class }
%i[create? edit? index? new? show? update?].each do |action|
permissions(action) do
it 'grants access to admins only' do
expect(policy).to permit(build(:admin), InternalUser.new)
%i[external_user teacher].each do |factory_name|
expect(policy).not_to permit(create(factory_name), InternalUser.new)
end
end
end
end
permissions :destroy? do
context 'with an admin user' do
it 'grants access to no one' do
%i[admin external_user teacher].each do |factory_name|
expect(policy).not_to permit(create(factory_name), build(:admin))
end
end
end
context 'with a non-admin user' do
it 'grants access to admins only' do
expect(policy).to permit(build(:admin), InternalUser.new)
%i[external_user teacher].each do |factory_name|
expect(policy).not_to permit(create(factory_name), create(:teacher))
end
end
end
end
end