summaryrefslogtreecommitdiff
path: root/spec/features
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-03-31 18:07:42 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2020-03-31 18:07:42 +0000
commit580622bdb3c762a8e89facd8a3946881ee480442 (patch)
tree3ac9d759da23f78f95f50684bd238a9f76839538 /spec/features
parentb211a4ea14d5e9ed9b0c248a4e8c5c1d85b542cb (diff)
downloadgitlab-ce-580622bdb3c762a8e89facd8a3946881ee480442.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/features')
-rw-r--r--spec/features/projects/container_registry_spec.rb192
1 files changed, 66 insertions, 126 deletions
diff --git a/spec/features/projects/container_registry_spec.rb b/spec/features/projects/container_registry_spec.rb
index 76c28c17858..a75da5f1080 100644
--- a/spec/features/projects/container_registry_spec.rb
+++ b/spec/features/projects/container_registry_spec.rb
@@ -17,167 +17,107 @@ describe 'Container Registry', :js do
stub_container_registry_tags(repository: :any, tags: [])
end
- describe 'Registry explorer is off' do
- before do
- stub_feature_flags(vue_container_registry_explorer: { enabled: false, thing: project.group })
- end
+ it 'has a page title set' do
+ visit_container_registry
+
+ expect(page).to have_title _('Container Registry')
+ end
- it 'has a page title set' do
+ context 'when there are no image repositories' do
+ it 'list page has no container title' do
visit_container_registry
- expect(page).to have_title _('Container Registry')
+ expect(page).to have_content _('There are no container images stored for this project')
end
- context 'when there are no image repositories' do
- it 'user visits container registry main page' do
- visit_container_registry
+ it 'list page has quickstart' do
+ visit_container_registry
- expect(page).to have_content _('no container images')
- end
+ 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 '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
+ 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
- end
- describe 'Registry explorer is on' do
- it 'has a page title set' do
+ it 'list page has a list of images' do
visit_container_registry
- expect(page).to have_title _('Container Registry')
+ expect(page).to have_content 'my/image'
end
- context 'when there are no image repositories' do
- it 'list page has no container title' do
- visit_container_registry
+ 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)
- expect(page).to have_content _('There are no container images stored for this project')
- end
+ find('[title="Remove repository"]').click
+ expect(find('.modal .modal-title')).to have_content _('Remove repository')
+ find('.modal .modal-footer .btn-danger').click
+ end
- it 'list page has quickstart' do
- visit_container_registry
+ it 'navigates to repo details' do
+ visit_container_registry_details('my/image')
- expect(page).to have_content _('Quick Start')
- end
+ expect(page).to have_content 'latest'
end
- context 'when there are image repositories' do
+ describe 'image repo details' do
before do
- stub_container_registry_tags(repository: %r{my/image}, tags: %w[latest], with_manifest: true)
- project.container_repositories << container_repository
+ stub_container_registry_tags(repository: %r{my/image}, tags: ('1'..'20').to_a, with_manifest: true)
+ visit_container_registry_details 'my/image'
end
- it 'list page has a list of images' do
- visit_container_registry
-
- expect(page).to have_content 'my/image'
+ it 'shows the details breadcrumb' do
+ expect(find('.breadcrumbs')).to have_link '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
+ it 'shows the image title' do
+ expect(page).to have_content 'my/image tags'
end
- it 'navigates to repo details' do
- visit_container_registry_details('my/image')
+ 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: ['1']) { service }
- expect(page).to have_content 'latest'
+ first('.js-delete-registry').click
+ expect(find('.modal .modal-title')).to have_content _('Remove tag')
+ find('.modal .modal-footer .btn-danger').click
end
- describe 'image repo details' do
- before do
- stub_container_registry_tags(repository: %r{my/image}, tags: ('1'..'20').to_a, with_manifest: true)
- 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: ['1']) { service }
-
- first('.js-delete-registry').click
- expect(find('.modal .modal-title')).to have_content _('Remove tag')
- find('.modal .modal-footer .btn-danger').click
- end
-
- it('pagination navigate to the second page') do
- visit_second_page
- expect(page).to have_content '20'
- end
+ it('pagination navigate to the second page') do
+ visit_second_page
+ expect(page).to have_content '20'
end
end
+ end
- context 'when there are more than 10 images' do
- before do
- create_list(:container_repository, 12, project: project)
- project.container_repositories << container_repository
- visit_container_registry
- end
+ context 'when there are more than 10 images' do
+ before do
+ create_list(:container_repository, 12, project: project)
+ project.container_repositories << container_repository
+ visit_container_registry
+ end
- it 'shows pagination' do
- expect(page).to have_css '.gl-pagination'
- end
+ it 'shows pagination' do
+ expect(page).to have_css '.gl-pagination'
+ end
- it 'pagination goes to second page' do
- visit_second_page
- expect(page).to have_content 'my/image'
- end
+ it 'pagination goes to second page' do
+ visit_second_page
+ expect(page).to have_content 'my/image'
+ end
- it 'pagination is preserved after navigating back from details' do
- visit_second_page
- click_link 'my/image'
- breadcrumb = find '.breadcrumbs'
- breadcrumb.click_link 'Container Registry'
- expect(page).to have_content 'my/image'
- end
+ it 'pagination is preserved after navigating back from details' do
+ visit_second_page
+ click_link 'my/image'
+ breadcrumb = find '.breadcrumbs'
+ breadcrumb.click_link 'Container Registry'
+ expect(page).to have_content 'my/image'
end
end