1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Projects::Aws::ConfigurationController, feature_category: :five_minute_production_app do
let_it_be(:project) { create(:project, :public) }
let_it_be(:url) { project_aws_configuration_path(project) }
let_it_be(:user_guest) { create(:user, guest_of: project) }
let_it_be(:user_developer) { create(:user, developer_of: project) }
let_it_be(:user_maintainer) { create(:user, maintainer_of: project) }
let_it_be(:unauthorized_members) { [user_guest, user_developer] }
let_it_be(:authorized_members) { [user_maintainer] }
context 'when accessed by unauthorized members' do
it 'returns not found on GET request' do
unauthorized_members.each do |unauthorized_member|
sign_in(unauthorized_member)
get url
expect_snowplow_event(
category: 'Projects::Aws::ConfigurationController',
action: 'error_invalid_user',
label: nil,
project: project,
user: unauthorized_member
)
expect(response).to have_gitlab_http_status(:not_found)
end
end
end
context 'when accessed by authorized members' do
it 'returns successful' do
authorized_members.each do |authorized_member|
sign_in(authorized_member)
get url
expect(response).to be_successful
expect(response).to render_template('projects/aws/configuration/index')
end
end
include_examples 'requires feature flag `cloudseed_aws` enabled' do
subject { get url }
let_it_be(:user) { user_maintainer }
end
end
end
|