debian-mirror-gitlab/spec/policies/namespaces/project_namespace_policy_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

48 lines
1.2 KiB
Ruby
Raw Normal View History

2021-11-18 22:05:49 +05:30
# frozen_string_literal: true
require 'spec_helper'
2022-01-26 12:08:38 +05:30
RSpec.describe Namespaces::ProjectNamespacePolicy do
2021-11-18 22:05:49 +05:30
let_it_be(:parent) { create(:namespace) }
2021-12-11 22:18:48 +05:30
let_it_be(:project) { create(:project, namespace: parent) }
let_it_be(:namespace) { project.project_namespace }
2021-11-18 22:05:49 +05:30
let(:permissions) do
[:owner_access, :create_projects, :admin_namespace, :read_namespace,
2022-07-16 23:28:13 +05:30
:read_statistics, :transfer_projects, :admin_package,
:create_jira_connect_subscription]
2021-11-18 22:05:49 +05:30
end
subject { described_class.new(current_user, namespace) }
context 'with no user' do
let_it_be(:current_user) { nil }
it { is_expected.to be_disallowed(*permissions) }
end
context 'regular user' do
let_it_be(:current_user) { create(:user) }
it { is_expected.to be_disallowed(*permissions) }
end
context 'parent owner' do
2022-04-04 11:22:00 +05:30
let_it_be(:current_user) { parent.first_owner }
2021-11-18 22:05:49 +05:30
it { is_expected.to be_disallowed(*permissions) }
end
context 'admin' do
let_it_be(:current_user) { create(:admin) }
context 'when admin mode is enabled', :enable_admin_mode do
2022-01-26 12:08:38 +05:30
it { is_expected.to be_disallowed(*permissions) }
2021-11-18 22:05:49 +05:30
end
context 'when admin mode is disabled' do
it { is_expected.to be_disallowed(*permissions) }
end
end
end