40 lines
1.2 KiB
Ruby
40 lines
1.2 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'rails_helper'
|
|
|
|
describe 'Authorization' do
|
|
context 'when being an admin' do
|
|
let(:user) { FactoryBot.create(:admin) }
|
|
|
|
before { allow_any_instance_of(ApplicationController).to receive(:current_user).and_return(user) }
|
|
|
|
[Consumer, ExecutionEnvironment, Exercise, FileType, InternalUser].each do |model|
|
|
expect_permitted_path(:"new_#{model.model_name.singular}_path")
|
|
end
|
|
end
|
|
|
|
context 'with being an external user' do
|
|
let(:user) { FactoryBot.create(:external_user) }
|
|
|
|
before { allow_any_instance_of(ApplicationController).to receive(:current_user).and_return(user) }
|
|
|
|
[Consumer, ExecutionEnvironment, Exercise, FileType, InternalUser].each do |model|
|
|
expect_forbidden_path(:"new_#{model.model_name.singular}_path")
|
|
end
|
|
end
|
|
|
|
context 'with being a teacher' do
|
|
let(:user) { FactoryBot.create(:teacher) }
|
|
|
|
before { allow_any_instance_of(ApplicationController).to receive(:current_user).and_return(user) }
|
|
|
|
[Consumer, InternalUser, ExecutionEnvironment, FileType].each do |model|
|
|
expect_forbidden_path(:"new_#{model.model_name.singular}_path")
|
|
end
|
|
|
|
[Exercise].each do |model|
|
|
expect_permitted_path(:"new_#{model.model_name.singular}_path")
|
|
end
|
|
end
|
|
end
|