debian-mirror-gitlab/spec/features/groups/container_registry_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

128 lines
3.7 KiB
Ruby
Raw Normal View History

2020-04-08 14:13:33 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-06-23 00:09:42 +05:30
RSpec.describe 'Container Registry', :js do
2020-04-08 14:13:33 +05:30
let(:user) { create(:user) }
let(:group) { create(:group) }
let(:project) { create(:project, namespace: group) }
let(:container_repository) do
create(:container_repository, name: 'my/image')
end
before do
group.add_owner(user)
sign_in(user)
stub_container_registry_config(enabled: true)
stub_container_registry_tags(repository: :any, tags: [])
2021-11-18 22:05:49 +05:30
stub_container_registry_info
2020-04-08 14:13:33 +05:30
end
it 'has a page title set' do
visit_container_registry
expect(page).to have_title _('Container Registry')
end
2020-06-23 00:09:42 +05:30
it 'sidebar menu is open' do
visit_container_registry
sidebar = find('.nav-sidebar')
expect(sidebar).to have_link _('Container Registry')
end
2020-04-08 14:13:33 +05:30
context 'when there are no image repositories' do
it 'list page has no container title' do
visit_container_registry
expect(page).to have_content _('There are no container images available in this group')
end
end
context 'when there are image repositories' do
before do
stub_container_registry_tags(repository: %r{my/image}, tags: %w[latest], with_manifest: true)
project.container_repositories << container_repository
end
it 'list page has a list of images' do
visit_container_registry
expect(page).to have_content 'my/image'
end
it 'navigates to repo details' do
visit_container_registry_details('my/image')
expect(page).to have_content 'latest'
end
2021-11-18 22:05:49 +05:30
[ContainerRegistry::Path::InvalidRegistryPathError, Faraday::Error].each do |error_class|
context "when there is a #{error_class}" do
before do
expect(::ContainerRegistry::Client).to receive(:registry_info).and_raise(error_class, nil, nil)
end
it_behaves_like 'handling feature network errors with the container registry'
end
end
2020-04-08 14:13:33 +05:30
describe 'image repo details' do
before do
visit_container_registry_details 'my/image'
end
it 'shows the details breadcrumb' do
expect(find('.breadcrumbs')).to have_link 'my/image'
end
it 'shows the image title' do
2021-04-17 20:07:23 +05:30
expect(page).to have_content 'my/image'
end
it 'shows the image tags' do
2022-01-26 12:08:38 +05:30
expect(page).to have_content '1 tag'
2021-04-17 20:07:23 +05:30
first_tag = first('[data-testid="name"]')
expect(first_tag).to have_content 'latest'
2020-04-08 14:13:33 +05:30
end
it 'user removes a specific tag from container repository' do
service = double('service')
expect(service).to receive(:execute).with(container_repository) { { status: :success } }
expect(Projects::ContainerRepository::DeleteTagsService).to receive(:new).with(container_repository.project, user, tags: ['latest']) { service }
2021-11-18 22:05:49 +05:30
first('[data-testid="additional-actions"]').click
2020-07-28 23:09:34 +05:30
first('[data-testid="single-delete-button"]').click
2020-04-08 14:13:33 +05:30
expect(find('.modal .modal-title')).to have_content _('Remove tag')
find('.modal .modal-footer .btn-danger').click
end
2022-05-07 20:08:51 +05:30
it_behaves_like 'rejecting tags destruction for an importing repository on', tags: ['latest']
2020-04-08 14:13:33 +05:30
end
end
2021-01-29 00:20:46 +05:30
context 'when an image has the same name as the subgroup' do
before do
stub_container_registry_tags(tags: %w[latest], with_manifest: true)
project.container_repositories << create(:container_repository, name: group.name)
visit_container_registry
end
it 'details page loads properly' do
find('a[data-testid="details-link"]').click
expect(page).to have_content 'latest'
end
end
2020-04-08 14:13:33 +05:30
def visit_container_registry
visit group_container_registries_path(group)
end
def visit_container_registry_details(name)
visit_container_registry
click_link(name)
end
end