Commit 435be144 authored by Alexandru Croitor's avatar Alexandru Croitor

Fix reply to discussion on promoted epic

Regenerate discussion_id for notes that are being copied over to the
epic when issue is promoted to epic.

https://gitlab.com/gitlab-org/gitlab-ee/issues/11445
parent 1def0719
...@@ -23,10 +23,14 @@ module Issuable ...@@ -23,10 +23,14 @@ module Issuable
end end
def rewrite_notes def rewrite_notes
new_discussion_ids = {}
original_entity.notes_with_associations.find_each do |note| original_entity.notes_with_associations.find_each do |note|
new_note = note.dup new_note = note.dup
new_discussion_ids[note.discussion_id] ||= Discussion.discussion_id(new_note)
new_params = { new_params = {
project: new_entity.project, noteable: new_entity, project: new_entity.project,
noteable: new_entity,
discussion_id: new_discussion_ids[note.discussion_id],
note: rewrite_content(new_note.note), note: rewrite_content(new_note.note),
note_html: nil, note_html: nil,
created_at: note.created_at, created_at: note.created_at,
......
...@@ -165,5 +165,18 @@ describe Issuable::Clone::ContentRewriter do ...@@ -165,5 +165,18 @@ describe Issuable::Clone::ContentRewriter do
expect(note.note_html).not_to eq(new_note.note_html) expect(note.note_html).not_to eq(new_note.note_html)
end end
end end
context "discussion notes" do
let(:note) { create(:note, noteable: original_issue, note: "sample note", project: project1) }
let!(:discussion) { create(:discussion_note_on_issue, in_reply_to: note, note: "reply to sample note") }
it 'rewrites discussion correctly' do
subject.execute
expect(new_issue.notes.count).to eq(original_issue.notes.count)
expect(new_issue.notes.where(discussion_id: discussion.discussion_id).count).to eq(0)
expect(original_issue.notes.where(discussion_id: discussion.discussion_id).count).to eq(1)
end
end
end end
end 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