
* Correct sorting in table * Modify page when nested in exercises * Fix links between pages * Link from statistics page to programming_groups/index * Link from submission page to programming_groups/<id> * Allow filtering for exercise ID on ProgrammingGroup#index * Add search fields for internal and external user id on pg/index
47 lines
1.4 KiB
Ruby
47 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
RSpec.describe ProgrammingGroupPolicy do
|
|
subject(:policy) { described_class }
|
|
|
|
let(:programming_group) { build(:programming_group) }
|
|
|
|
%i[index? destroy? show? edit? update?].each do |action|
|
|
permissions(action) do
|
|
it 'grants access to admins only' do
|
|
expect(policy).to permit(create(:admin), programming_group)
|
|
%i[external_user teacher].each do |factory_name|
|
|
expect(policy).not_to permit(create(factory_name), programming_group)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
%i[new? create?].each do |action|
|
|
permissions(action) do
|
|
it 'grants access to everyone' do
|
|
%i[external_user teacher admin].each do |factory_name|
|
|
expect(policy).to permit(create(factory_name), programming_group)
|
|
end
|
|
end
|
|
end
|
|
|
|
permissions(:stream_sync_editor?) do
|
|
it 'grants access to admins' do
|
|
expect(policy).to permit(create(:admin), programming_group)
|
|
end
|
|
|
|
it 'grants access to members of the programming group' do
|
|
programming_group.users do |user|
|
|
expect(policy).to permit(user, programming_group)
|
|
end
|
|
end
|
|
|
|
it 'does not grant access to someone who is not a member of the programming group' do
|
|
expect(policy).not_to permit(create(:external_user), programming_group)
|
|
end
|
|
end
|
|
end
|
|
end
|