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

72 lines
2.0 KiB
Ruby

# frozen_string_literal: true
require 'rails_helper'
describe ExecutionEnvironmentPolicy do
subject(:policy) { described_class }
let(:execution_environment) { build(:ruby) }
permissions :index? do
it 'grants access to admins' do
expect(policy).to permit(build(:admin), execution_environment)
end
it 'grants access to teachers' do
expect(policy).to permit(build(:teacher), execution_environment)
end
it 'does not grant access to external users' do
expect(policy).not_to permit(build(:external_user), execution_environment)
end
end
%i[execute_command? shell? statistics? show?].each do |action|
permissions(action) do
it 'grants access to admins' do
expect(policy).to permit(build(:admin), execution_environment)
end
it 'grants access to authors' do
expect(policy).to permit(execution_environment.author, execution_environment)
end
it 'does not grant access to all other users' do
%i[external_user teacher].each do |factory_name|
expect(policy).not_to permit(build(factory_name), execution_environment)
end
end
end
end
%i[destroy? edit? update? new? create?].each do |action|
permissions(action) do
it 'grants access to admins' do
expect(policy).to permit(build(:admin), execution_environment)
end
it 'does not grant access to authors' do
expect(policy).not_to permit(execution_environment.author, execution_environment)
end
it 'does not grant access to all other users' do
%i[external_user teacher].each do |factory_name|
expect(policy).not_to permit(build(factory_name), execution_environment)
end
end
end
end
permissions :sync_all_to_runner_management? do
it 'grants access to the admin' do
expect(policy).to permit(build(:admin))
end
it 'does not grant access to all other users' do
%i[external_user teacher].each do |factory_name|
expect(policy).not_to permit(build(factory_name))
end
end
end
end