2021-03-02 16:11:07 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Gitlab::WordDiff::Parser do
|
|
|
|
subject(:parser) { described_class.new }
|
|
|
|
|
|
|
|
describe '#parse' do
|
|
|
|
subject { parser.parse(diff.lines).to_a }
|
|
|
|
|
|
|
|
let(:diff) do
|
|
|
|
<<~EOF
|
|
|
|
@@ -1,14 +1,13 @@
|
|
|
|
~
|
|
|
|
Unchanged line
|
|
|
|
~
|
|
|
|
~
|
|
|
|
-Old change
|
|
|
|
+New addition
|
|
|
|
unchanged content
|
|
|
|
~
|
|
|
|
@@ -50,14 +50,13 @@
|
|
|
|
+First change
|
|
|
|
same same same_
|
|
|
|
-removed_
|
|
|
|
+added_
|
|
|
|
end of the line
|
|
|
|
~
|
|
|
|
~
|
|
|
|
EOF
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns a collection of lines' do
|
|
|
|
diff_lines = subject
|
|
|
|
|
|
|
|
aggregate_failures do
|
|
|
|
expect(diff_lines.count).to eq(7)
|
|
|
|
|
2021-03-22 23:09:04 -04:00
|
|
|
expect(diff_lines.map { |line| diff_line_attributes(line) }).to eq(
|
2021-03-02 16:11:07 -05:00
|
|
|
[
|
2021-03-22 23:09:04 -04:00
|
|
|
{ index: 0, old_pos: 1, new_pos: 1, text: '', type: nil, marker_ranges: [] },
|
|
|
|
{ index: 1, old_pos: 2, new_pos: 2, text: 'Unchanged line', type: nil, marker_ranges: [] },
|
|
|
|
{ index: 2, old_pos: 3, new_pos: 3, text: '', type: nil, marker_ranges: [] },
|
|
|
|
{ index: 3, old_pos: 4, new_pos: 4, text: 'Old changeNew addition unchanged content', type: nil,
|
|
|
|
marker_ranges: [
|
|
|
|
Gitlab::MarkerRange.new(0, 9, mode: :deletion),
|
|
|
|
Gitlab::MarkerRange.new(10, 21, mode: :addition)
|
|
|
|
] },
|
|
|
|
|
|
|
|
{ index: 4, old_pos: 50, new_pos: 50, text: '@@ -50,14 +50,13 @@', type: 'match', marker_ranges: [] },
|
|
|
|
{ index: 5, old_pos: 50, new_pos: 50, text: 'First change same same same_removed_added_end of the line', type: nil,
|
|
|
|
marker_ranges: [
|
|
|
|
Gitlab::MarkerRange.new(0, 11, mode: :addition),
|
|
|
|
Gitlab::MarkerRange.new(28, 35, mode: :deletion),
|
|
|
|
Gitlab::MarkerRange.new(36, 41, mode: :addition)
|
|
|
|
] },
|
|
|
|
|
|
|
|
{ index: 6, old_pos: 51, new_pos: 51, text: '', type: nil, marker_ranges: [] }
|
2021-03-02 16:11:07 -05:00
|
|
|
]
|
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'restarts object index after several calls to Enumerator' do
|
|
|
|
enumerator = parser.parse(diff.lines)
|
|
|
|
|
|
|
|
2.times do
|
|
|
|
expect(enumerator.first.index).to eq(0)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when diff is empty' do
|
|
|
|
let(:diff) { '' }
|
|
|
|
|
|
|
|
it { is_expected.to eq([]) }
|
|
|
|
end
|
|
|
|
end
|
2021-03-22 23:09:04 -04:00
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def diff_line_attributes(diff_line)
|
|
|
|
{
|
|
|
|
index: diff_line.index,
|
|
|
|
old_pos: diff_line.old_pos,
|
|
|
|
new_pos: diff_line.new_pos,
|
|
|
|
text: diff_line.text,
|
|
|
|
type: diff_line.type,
|
|
|
|
marker_ranges: diff_line.marker_ranges
|
|
|
|
}
|
|
|
|
end
|
2021-03-02 16:11:07 -05:00
|
|
|
end
|