debian-mirror-gitlab/spec/policies/clusters/agent_policy_spec.rb
2023-07-09 08:55:56 +05:30

46 lines
1.2 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Clusters::AgentPolicy do
let(:cluster_agent) { create(:cluster_agent, name: 'agent' ) }
let(:user) { create(:admin) }
let(:policy) { described_class.new(user, cluster_agent) }
let(:project) { cluster_agent.project }
describe 'rules' do
it { expect(policy).to be_disallowed :read_cluster_agent }
context 'when developer' do
before do
project.add_developer(user)
end
it { expect(policy).to be_disallowed :admin_cluster }
end
context 'when maintainer' do
before do
project.add_maintainer(user)
end
it { expect(policy).to be_allowed :admin_cluster }
end
context 'when agent is ci_access authorized for project members' do
before do
allow(cluster_agent).to receive(:ci_access_authorized_for?).with(user).and_return(true)
end
it { expect(policy).to be_allowed :read_cluster_agent }
end
context 'when agent is user_access authorized for project members' do
before do
allow(cluster_agent).to receive(:user_access_authorized_for?).with(user).and_return(true)
end
it { expect(policy).to be_allowed :read_cluster_agent }
end
end
end