summaryrefslogtreecommitdiff
path: root/spec/features/projects/container_registry_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/features/projects/container_registry_spec.rb')
-rw-r--r--spec/features/projects/container_registry_spec.rb161
1 files changed, 161 insertions, 0 deletions
diff --git a/spec/features/projects/container_registry_spec.rb b/spec/features/projects/container_registry_spec.rb
new file mode 100644
index 00000000000..02b2d03a880
--- /dev/null
+++ b/spec/features/projects/container_registry_spec.rb
@@ -0,0 +1,161 @@
+# frozen_string_literal: true
+
+require 'spec_helper'
+
+describe 'Container Registry', :js do
+ let(:user) { create(:user) }
+ let(:project) { create(:project) }
+
+ let(:container_repository) do
+ create(:container_repository, name: 'my/image')
+ end
+
+ before do
+ sign_in(user)
+ project.add_developer(user)
+ stub_container_registry_config(enabled: true)
+ stub_container_registry_tags(repository: :any, tags: [])
+ end
+
+ describe 'Registry explorer is off' do
+ before do
+ stub_feature_flags(vue_container_registry_explorer: false)
+ end
+
+ it 'has a page title set' do
+ visit_container_registry
+
+ expect(page).to have_title _('Container Registry')
+ end
+
+ context 'when there are no image repositories' do
+ it 'user visits container registry main page' do
+ visit_container_registry
+
+ expect(page).to have_content _('no container images')
+ 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 'user wants to see multi-level container repository' do
+ visit_container_registry
+
+ expect(page).to have_content 'my/image'
+ end
+
+ it 'user removes entire container repository', :sidekiq_might_not_need_inline do
+ visit_container_registry
+
+ expect_any_instance_of(ContainerRepository).to receive(:delete_tags!).and_return(true)
+
+ click_on(class: 'js-remove-repo')
+ expect(find('.modal .modal-title')).to have_content _('Remove repository')
+ find('.modal .modal-footer .btn-danger').click
+ end
+
+ it 'user removes a specific tag from container repository' do
+ visit_container_registry
+
+ find('.js-toggle-repo').click
+ wait_for_requests
+
+ 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 }
+
+ click_on(class: 'js-delete-registry-row', visible: false)
+ expect(find('.modal .modal-title')).to have_content _('Remove tag')
+ find('.modal .modal-footer .btn-danger').click
+ end
+ end
+ end
+
+ describe 'Registry explorer is on' do
+ it 'has a page title set' do
+ visit_container_registry
+
+ expect(page).to have_title _('Container Registry')
+ end
+
+ 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 stored for this project')
+ end
+
+ it 'list page has quickstart' do
+ visit_container_registry
+
+ expect(page).to have_content _('Quick Start')
+ 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 'user removes entire container repository', :sidekiq_might_not_need_inline do
+ visit_container_registry
+
+ expect_any_instance_of(ContainerRepository).to receive(:delete_tags!).and_return(true)
+
+ find('[title="Remove repository"]').click
+ expect(find('.modal .modal-title')).to have_content _('Remove repository')
+ find('.modal .modal-footer .btn-danger').click
+ end
+
+ it 'navigates to repo details' do
+ visit_container_registry_details('my/image')
+
+ expect(page).to have_content 'latest'
+ end
+
+ 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
+ expect(page).to have_content 'my/image tags'
+ 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 }
+
+ click_on(class: 'js-delete-registry')
+ expect(find('.modal .modal-title')).to have_content _('Remove tag')
+ find('.modal .modal-footer .btn-danger').click
+ end
+ end
+ end
+ end
+
+ def visit_container_registry
+ visit project_container_registry_index_path(project)
+ end
+
+ def visit_container_registry_details(name)
+ visit_container_registry
+ click_link(name)
+ end
+end