summaryrefslogtreecommitdiff
path: root/spec/services
diff options
context:
space:
mode:
authorGrzegorz Bizon <grzesiek.bizon@gmail.com>2016-02-23 14:18:54 +0100
committerGrzegorz Bizon <grzesiek.bizon@gmail.com>2016-03-17 07:39:15 +0100
commit4cbe87d50ecfad9b97ba76f05935124676c96052 (patch)
treea89e4334342f1f3095f2e98c98b41e0690b58ade /spec/services
parent5ed8a1e107b9b6f91257e5afdd370f0552078786 (diff)
downloadgitlab-ce-4cbe87d50ecfad9b97ba76f05935124676c96052.tar.gz
Rewrite references in issue description when moving it
Diffstat (limited to 'spec/services')
-rw-r--r--spec/services/issues/move_service_spec.rb25
1 files changed, 19 insertions, 6 deletions
diff --git a/spec/services/issues/move_service_spec.rb b/spec/services/issues/move_service_spec.rb
index 3b81cc90c61..8d9cc09ffc7 100644
--- a/spec/services/issues/move_service_spec.rb
+++ b/spec/services/issues/move_service_spec.rb
@@ -4,8 +4,8 @@ describe Issues::MoveService, services: true do
let(:user) { create(:user) }
let(:title) { 'Some issue' }
let(:description) { 'Some issue description' }
- let(:old_issue) { create(:issue, title: title, description: description) }
- let(:old_project) { old_issue.project }
+ let(:old_project) { create(:project) }
+ let(:old_issue) { create(:issue, title: title, description: description, project: old_project) }
let(:new_project) { create(:project) }
let(:move_service) { described_class.new(old_project, user, move_params, old_issue) }
@@ -61,13 +61,12 @@ describe Issues::MoveService, services: true do
expect(old_issue.closed?).to be true
end
- it 'persists changes to old and new issue' do
- expect(new_issue.changed?).to be false
- expect(old_issue.changed?).to be false
+ it 'persists new issue' do
+ expect(new_issue.persisted?).to be true
end
end
- context 'notes exist' do
+ context 'issue with notes' do
let(:note_contents) do
['Some system note 1', 'Some comment', 'Some system note 2']
end
@@ -91,6 +90,20 @@ describe Issues::MoveService, services: true do
expect(new_notes.last).to match /^Moved from/
end
end
+
+ describe 'rewritting references' do
+ include_context 'issue move executed'
+
+ context 'issue reference' do
+ let(:another_issue) { create(:issue, project: old_project) }
+ let(:description) { "Some description #{another_issue.to_reference}" }
+
+ it 'rewrites referenced issues creating cross project reference' do
+ expect(new_issue.description)
+ .to eq "Some description #{old_project.to_reference}#{another_issue.to_reference}"
+ end
+ end
+ end
end
end