debian-mirror-gitlab/spec/models/concerns/clusters/agents/authorization_config_scopes_spec.rb
2021-12-11 22:18:48 +05:30

21 lines
1.3 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Clusters::Agents::AuthorizationConfigScopes do
describe '.with_available_ci_access_fields' do
let(:project) { create(:project) }
let!(:agent_authorization_0) { create(:agent_project_authorization, project: project) }
let!(:agent_authorization_1) { create(:agent_project_authorization, project: project, config: { access_as: {} }) }
let!(:agent_authorization_2) { create(:agent_project_authorization, project: project, config: { access_as: { agent: {} } }) }
let!(:impersonate_authorization) { create(:agent_project_authorization, project: project, config: { access_as: { impersonate: {} } }) }
let!(:ci_user_authorization) { create(:agent_project_authorization, project: project, config: { access_as: { ci_user: {} } }) }
let!(:ci_job_authorization) { create(:agent_project_authorization, project: project, config: { access_as: { ci_job: {} } }) }
let!(:unexpected_authorization) { create(:agent_project_authorization, project: project, config: { access_as: { unexpected: {} } }) }
subject { Clusters::Agents::ProjectAuthorization.with_available_ci_access_fields(project) }
it { is_expected.to contain_exactly(agent_authorization_0, agent_authorization_1, agent_authorization_2) }
end
end