Commit 06ae33b8 authored by Heinrich Lee Yu's avatar Heinrich Lee Yu

Clear closure references when issue is reopened

This prevents incorrect references when the reopened issue is closed
again.

Changelog: fixed
parent ff05c80c
......@@ -204,6 +204,8 @@ class Issue < ApplicationRecord
before_transition closed: :opened do |issue|
issue.closed_at = nil
issue.closed_by = nil
issue.clear_closure_reason_references
end
end
......@@ -379,6 +381,11 @@ class Issue < ApplicationRecord
!duplicated_to_id.nil?
end
def clear_closure_reason_references
self.moved_to_id = nil
self.duplicated_to_id = nil
end
def can_move?(user, to_project = nil)
if to_project
return false unless user.can?(:admin_issue, to_project)
......
......@@ -167,6 +167,13 @@ module EE
!!promoted_to_epic_id
end
override :clear_closure_reason_references
def clear_closure_reason_references
super
self.promoted_to_epic_id = nil
end
class_methods do
extend ::Gitlab::Utils::Override
......
......@@ -492,6 +492,15 @@ RSpec.describe Issue do
end
end
describe '#reopen' do
let(:promoted_to_epic) { create(:epic) }
let(:issue) { create(:issue, :closed, promoted_to_epic: promoted_to_epic) }
it 'clears promoted_to_epic_id for promoted issues' do
expect { issue.reopen }.to change { issue.promoted_to_epic_id }.from(promoted_to_epic.id).to(nil)
end
end
context 'ES related specs', :elastic do
before do
stub_ee_application_setting(elasticsearch_indexing: true)
......
......@@ -306,7 +306,7 @@ RSpec.describe Issue do
end
describe '#reopen' do
let(:issue) { create(:issue, project: reusable_project, state: 'closed', closed_at: Time.current, closed_by: user) }
let_it_be_with_reload(:issue) { create(:issue, project: reusable_project, state: 'closed', closed_at: Time.current, closed_by: user) }
it 'sets closed_at to nil when an issue is reopened' do
expect { issue.reopen }.to change { issue.closed_at }.to(nil)
......@@ -316,6 +316,22 @@ RSpec.describe Issue do
expect { issue.reopen }.to change { issue.closed_by }.from(user).to(nil)
end
it 'clears moved_to_id for moved issues' do
moved_issue = create(:issue)
issue.update!(moved_to_id: moved_issue.id)
expect { issue.reopen }.to change { issue.moved_to_id }.from(moved_issue.id).to(nil)
end
it 'clears duplicated_to_id for duplicated issues' do
duplicate_issue = create(:issue)
issue.update!(duplicated_to_id: duplicate_issue.id)
expect { issue.reopen }.to change { issue.duplicated_to_id }.from(duplicate_issue.id).to(nil)
end
it 'changes the state to opened' do
expect { issue.reopen }.to change { issue.state_id }.from(described_class.available_states[:closed]).to(described_class.available_states[:opened])
end
......
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