57 lines
1.4 KiB
Ruby
57 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
describe API::GroupContainerRepositories do
|
|
set(:group) { create(:group, :private) }
|
|
set(:project) { create(:project, :private, group: group) }
|
|
let(:reporter) { create(:user) }
|
|
let(:guest) { create(:user) }
|
|
|
|
let(:root_repository) { create(:container_repository, :root, project: project) }
|
|
let(:test_repository) { create(:container_repository, project: project) }
|
|
|
|
let(:users) do
|
|
{
|
|
anonymous: nil,
|
|
guest: guest,
|
|
reporter: reporter
|
|
}
|
|
end
|
|
|
|
let(:api_user) { reporter }
|
|
|
|
before do
|
|
group.add_reporter(reporter)
|
|
group.add_guest(guest)
|
|
|
|
stub_feature_flags(container_registry_api: true)
|
|
stub_container_registry_config(enabled: true)
|
|
|
|
root_repository
|
|
test_repository
|
|
end
|
|
|
|
describe 'GET /groups/:id/registry/repositories' do
|
|
let(:url) { "/groups/#{group.id}/registry/repositories" }
|
|
|
|
subject { get api(url, api_user) }
|
|
|
|
it_behaves_like 'rejected container repository access', :guest, :forbidden
|
|
it_behaves_like 'rejected container repository access', :anonymous, :not_found
|
|
|
|
it_behaves_like 'returns repositories for allowed users', :reporter, 'group' do
|
|
let(:object) { group }
|
|
end
|
|
|
|
context 'with invalid group id' do
|
|
let(:url) { '/groups/123412341234/registry/repositories' }
|
|
|
|
it 'returns not found' do
|
|
subject
|
|
|
|
expect(response).to have_gitlab_http_status(:not_found)
|
|
end
|
|
end
|
|
end
|
|
end
|