2016-03-07 07:09:53 -05:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2016-03-20 05:11:26 -04:00
|
|
|
describe Gitlab::Gfm::ReferenceRewriter do
|
2016-03-07 07:09:53 -05:00
|
|
|
let(:text) { 'some text' }
|
|
|
|
let(:old_project) { create(:project) }
|
|
|
|
let(:new_project) { create(:project) }
|
2016-03-19 13:58:52 -04:00
|
|
|
let(:user) { create(:user) }
|
|
|
|
|
|
|
|
before { old_project.team << [user, :guest] }
|
2016-03-07 07:09:53 -05:00
|
|
|
|
2016-03-20 05:11:26 -04:00
|
|
|
describe '#rewrite' do
|
2016-03-19 13:58:52 -04:00
|
|
|
subject do
|
2016-03-20 05:11:26 -04:00
|
|
|
described_class.new(text, old_project, user).rewrite(new_project)
|
2016-03-19 13:58:52 -04:00
|
|
|
end
|
2016-03-07 07:09:53 -05:00
|
|
|
|
|
|
|
context 'multiple issues and merge requests referenced' do
|
|
|
|
let!(:issue_first) { create(:issue, project: old_project) }
|
|
|
|
let!(:issue_second) { create(:issue, project: old_project) }
|
|
|
|
let!(:merge_request) { create(:merge_request, source_project: old_project) }
|
|
|
|
|
|
|
|
context 'plain text description' do
|
|
|
|
let(:text) { 'Description that references #1, #2 and !1' }
|
|
|
|
|
|
|
|
it { is_expected.to include issue_first.to_reference(new_project) }
|
|
|
|
it { is_expected.to include issue_second.to_reference(new_project) }
|
|
|
|
it { is_expected.to include merge_request.to_reference(new_project) }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'description with ignored elements' do
|
|
|
|
let(:text) do
|
|
|
|
"Hi. This references #1, but not `#2`\n" +
|
|
|
|
'<pre>and not !1</pre>'
|
|
|
|
end
|
|
|
|
|
|
|
|
it { is_expected.to include issue_first.to_reference(new_project) }
|
2016-05-23 19:37:59 -04:00
|
|
|
it { is_expected.not_to include issue_second.to_reference(new_project) }
|
|
|
|
it { is_expected.not_to include merge_request.to_reference(new_project) }
|
2016-03-07 07:09:53 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'description ambigous elements' do
|
2016-03-11 05:49:04 -05:00
|
|
|
context 'url' do
|
|
|
|
let(:url) { 'http://gitlab.com/#1' }
|
|
|
|
let(:text) { "This references #1, but not #{url}" }
|
2016-03-07 07:09:53 -05:00
|
|
|
|
2016-03-11 05:49:04 -05:00
|
|
|
it { is_expected.to include url }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'code' do
|
|
|
|
let(:text) { "#1, but not `[#1]`" }
|
|
|
|
it { is_expected.to eq "#{issue_first.to_reference(new_project)}, but not `[#1]`" }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'code reverse' do
|
|
|
|
let(:text) { "not `#1`, but #1" }
|
|
|
|
it { is_expected.to eq "not `#1`, but #{issue_first.to_reference(new_project)}" }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'code in random order' do
|
|
|
|
let(:text) { "#1, `#1`, #1, `#1`" }
|
|
|
|
let(:ref) { issue_first.to_reference(new_project) }
|
|
|
|
|
|
|
|
it { is_expected.to eq "#{ref}, `#1`, #{ref}, `#1`" }
|
|
|
|
end
|
2016-03-20 05:52:01 -04:00
|
|
|
|
|
|
|
context 'description with labels' do
|
|
|
|
let!(:label) { create(:label, id: 123, name: 'test', project: old_project) }
|
|
|
|
let(:project_ref) { old_project.to_reference }
|
|
|
|
|
|
|
|
context 'label referenced by id' do
|
|
|
|
let(:text) { '#1 and ~123' }
|
|
|
|
it { is_expected.to eq %Q{#{project_ref}#1 and #{project_ref}~123} }
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'label referenced by text' do
|
|
|
|
let(:text) { '#1 and ~"test"' }
|
|
|
|
it { is_expected.to eq %Q{#{project_ref}#1 and #{project_ref}~123} }
|
|
|
|
end
|
|
|
|
end
|
2016-03-11 05:49:04 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
context 'reference contains milestone' do
|
|
|
|
let(:milestone) { create(:milestone) }
|
|
|
|
let(:text) { "milestone ref: #{milestone.to_reference}" }
|
|
|
|
|
|
|
|
it { is_expected.to eq text }
|
2016-03-07 07:09:53 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|