# 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