diff options
author | Douwe Maan <douwe@gitlab.com> | 2017-08-11 15:14:39 +0000 |
---|---|---|
committer | Douwe Maan <douwe@gitlab.com> | 2017-08-11 15:14:39 +0000 |
commit | f662721eedbbbd145301f1c3c1724b5ac1adc69e (patch) | |
tree | cf0c157ab32ddedeabb549f12c98ab94682fbbc3 | |
parent | 2a4304aea7effb18ba36fc653b1989cf3599768d (diff) | |
parent | 21066e827ab6b957b0948b025745b563f01a00d5 (diff) | |
download | gitlab-ce-f662721eedbbbd145301f1c3c1724b5ac1adc69e.tar.gz |
Merge branch '35435-pending-delete-project-error-in-admin-interface-fix' into 'master'
Pending delete projects no longer return 500 error in Admins projects view
Closes #35435
See merge request !13389
4 files changed, 23 insertions, 1 deletions
diff --git a/app/finders/admin/projects_finder.rb b/app/finders/admin/projects_finder.rb index a5ba791a513..7176bfe22d6 100644 --- a/app/finders/admin/projects_finder.rb +++ b/app/finders/admin/projects_finder.rb @@ -18,7 +18,7 @@ class Admin::ProjectsFinder end def execute - items = Project.with_statistics + items = Project.without_deleted.with_statistics items = items.in_namespace(namespace_id) if namespace_id.present? items = items.where(visibility_level: visibility_level) if visibility_level.present? items = items.with_push if with_push.present? diff --git a/changelogs/unreleased/35435-pending-delete-project-error-in-admin-interface-fix.yml b/changelogs/unreleased/35435-pending-delete-project-error-in-admin-interface-fix.yml new file mode 100644 index 00000000000..8539615faac --- /dev/null +++ b/changelogs/unreleased/35435-pending-delete-project-error-in-admin-interface-fix.yml @@ -0,0 +1,4 @@ +--- +title: Project pending delete no longer return 500 error in admins projects view +merge_request: 13389 +author: diff --git a/spec/controllers/admin/projects_controller_spec.rb b/spec/controllers/admin/projects_controller_spec.rb index 65587064eb1..373260b3978 100644 --- a/spec/controllers/admin/projects_controller_spec.rb +++ b/spec/controllers/admin/projects_controller_spec.rb @@ -12,12 +12,24 @@ describe Admin::ProjectsController do it 'retrieves the project for the given visibility level' do get :index, visibility_level: [Gitlab::VisibilityLevel::PUBLIC] + expect(response.body).to match(project.name) end it 'does not retrieve the project' do get :index, visibility_level: [Gitlab::VisibilityLevel::INTERNAL] + expect(response.body).not_to match(project.name) end + + it 'does not respond with projects pending deletion' do + pending_delete_project = create(:project, pending_delete: true) + + get :index + + expect(response).to have_http_status(200) + expect(response.body).not_to match(pending_delete_project.name) + expect(response.body).to match(project.name) + end end end diff --git a/spec/finders/admin/projects_finder_spec.rb b/spec/finders/admin/projects_finder_spec.rb index 4e367d39cf3..28e36330029 100644 --- a/spec/finders/admin/projects_finder_spec.rb +++ b/spec/finders/admin/projects_finder_spec.rb @@ -38,6 +38,12 @@ describe Admin::ProjectsFinder do it { is_expected.to match_array([shared_project, public_project, internal_project, private_project]) } end + context 'with pending delete project' do + let!(:pending_delete_project) { create(:project, pending_delete: true) } + + it { is_expected.not_to include(pending_delete_project) } + end + context 'filter by namespace_id' do let(:namespace) { create(:namespace) } let!(:project_in_namespace) { create(:project, namespace: namespace) } |