debian-mirror-gitlab/spec/lib/gitlab/word_diff/parser_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

92 lines
2.5 KiB
Ruby
Raw Normal View History

2021-04-17 20:07:23 +05:30
# frozen_string_literal: true
2022-10-11 01:57:18 +05:30
require 'fast_spec_helper'
2021-04-17 20:07:23 +05:30
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-04-29 21:17:54 +05:30
expect(diff_lines.map { |line| diff_line_attributes(line) }).to eq(
2021-04-17 20:07:23 +05:30
[
2021-04-29 21:17:54 +05:30
{ 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,
2022-10-11 01:57:18 +05:30
marker_ranges: [
Gitlab::MarkerRange.new(0, 9, mode: :deletion),
Gitlab::MarkerRange.new(10, 21, mode: :addition)
] },
2021-04-29 21:17:54 +05:30
{ 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,
2022-10-11 01:57:18 +05:30
marker_ranges: [
Gitlab::MarkerRange.new(0, 11, mode: :addition),
Gitlab::MarkerRange.new(28, 35, mode: :deletion),
Gitlab::MarkerRange.new(36, 41, mode: :addition)
] },
2021-04-29 21:17:54 +05:30
{ index: 6, old_pos: 51, new_pos: 51, text: '', type: nil, marker_ranges: [] }
2021-04-17 20:07:23 +05:30
]
)
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-04-29 21:17:54 +05:30
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-04-17 20:07:23 +05:30
end