Commit 3557fd6b authored by Stan Hu's avatar Stan Hu

Gracefully handle marking a project deletion multiple times

If a user clicks on "Delete repository" on a project that has already
been marked for deletion, GitLab would previously throw a 500 Error due
to `NoMethodError: undefined method '[]' for nil:NilClass`. To fix this,
return a successful mark so that the user can see when the project is
slated for deletion.

Closes https://gitlab.com/gitlab-org/gitlab/issues/121730
parent cc506030
---
title: Gracefully handle marking a project deletion multiple times
merge_request: 22949
author:
type: fixed
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
module Projects module Projects
class MarkForDeletionService < BaseService class MarkForDeletionService < BaseService
def execute def execute
return if project.marked_for_deletion_at? return success if project.marked_for_deletion_at?
return unless project.feature_available?(:marking_project_for_deletion) return error('Cannot mark project for deletion: feature not supported') unless project.feature_available?(:marking_project_for_deletion)
result = ::Projects::UpdateService.new( result = ::Projects::UpdateService.new(
project, project,
......
...@@ -18,13 +18,11 @@ describe Projects::MarkForDeletionService do ...@@ -18,13 +18,11 @@ describe Projects::MarkForDeletionService do
end end
context 'marking project for deletion' do context 'marking project for deletion' do
before do
described_class.new(project, user).execute
end
it 'marks project as archived and marked for deletion' do it 'marks project as archived and marked for deletion' do
expect(Project.unscoped.all).to include(project) result = described_class.new(project, user).execute
expect(result[:status]).to eq(:success)
expect(Project.unscoped.all).to include(project)
expect(project.archived).to eq(true) expect(project.archived).to eq(true)
expect(project.marked_for_deletion_at).not_to be_nil expect(project.marked_for_deletion_at).not_to be_nil
expect(project.deleting_user).to eq(user) expect(project.deleting_user).to eq(user)
...@@ -34,11 +32,10 @@ describe Projects::MarkForDeletionService do ...@@ -34,11 +32,10 @@ describe Projects::MarkForDeletionService do
context 'marking project for deletion once again' do context 'marking project for deletion once again' do
let(:marked_for_deletion_at) { 2.days.ago } let(:marked_for_deletion_at) { 2.days.ago }
before do
described_class.new(project, user).execute
end
it 'does not change original date' do it 'does not change original date' do
result = described_class.new(project, user).execute
expect(result[:status]).to eq(:success)
expect(project.marked_for_deletion_at).to eq(marked_for_deletion_at.to_date) expect(project.marked_for_deletion_at).to eq(marked_for_deletion_at.to_date)
end end
end end
...@@ -58,6 +55,9 @@ describe Projects::MarkForDeletionService do ...@@ -58,6 +55,9 @@ describe Projects::MarkForDeletionService do
end end
it 'does not change project attributes' do it 'does not change project attributes' do
result = described_class.new(project, user).execute
expect(result[:status]).to eq(:error)
expect(Project.all).to include(project) expect(Project.all).to include(project)
expect(project.archived).to eq(false) expect(project.archived).to eq(false)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment