2018-09-19 08:26:28 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
shared_examples 'diff statistics' do |test_include_stats_flag: true|
|
|
|
|
def stub_stats_find_by_path(path, stats_mock)
|
|
|
|
expect_next_instance_of(Gitlab::Git::DiffStatsCollection) do |collection|
|
|
|
|
allow(collection).to receive(:find_by_path).and_call_original
|
|
|
|
expect(collection).to receive(:find_by_path).with(path).and_return(stats_mock)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when should request diff stats' do
|
|
|
|
it 'Repository#diff_stats is called' do
|
|
|
|
subject = described_class.new(diffable, collection_default_args)
|
|
|
|
|
|
|
|
expect(diffable.project.repository)
|
|
|
|
.to receive(:diff_stats)
|
|
|
|
.with(diffable.diff_refs.base_sha, diffable.diff_refs.head_sha)
|
|
|
|
.and_call_original
|
|
|
|
|
|
|
|
subject.diff_files
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'Gitlab::Diff::File is initialized with diff stats' do
|
|
|
|
subject = described_class.new(diffable, collection_default_args)
|
|
|
|
|
|
|
|
stats_mock = double(Gitaly::DiffStats, path: '.gitignore', additions: 758, deletions: 120)
|
|
|
|
stub_stats_find_by_path(stub_path, stats_mock)
|
|
|
|
|
|
|
|
diff_file = subject.diff_files.find { |file| file.new_path == stub_path }
|
|
|
|
|
|
|
|
expect(diff_file.added_lines).to eq(stats_mock.additions)
|
|
|
|
expect(diff_file.removed_lines).to eq(stats_mock.deletions)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when should not request diff stats' do
|
|
|
|
it 'Repository#diff_stats is not called' do
|
|
|
|
collection_default_args[:diff_options][:include_stats] = false
|
|
|
|
|
|
|
|
subject = described_class.new(diffable, collection_default_args)
|
|
|
|
|
|
|
|
expect(diffable.project.repository).not_to receive(:diff_stats)
|
|
|
|
|
|
|
|
subject.diff_files
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2018-12-04 08:15:19 -05:00
|
|
|
|
|
|
|
shared_examples 'unfoldable diff' do
|
|
|
|
let(:subject) { described_class.new(diffable, diff_options: nil) }
|
|
|
|
|
|
|
|
it 'calls Gitlab::Diff::File#unfold_diff_lines with correct position' do
|
|
|
|
position = instance_double(Gitlab::Diff::Position, file_path: 'README')
|
|
|
|
readme_file = instance_double(Gitlab::Diff::File, file_path: 'README')
|
|
|
|
other_file = instance_double(Gitlab::Diff::File, file_path: 'foo.rb')
|
|
|
|
nil_path_file = instance_double(Gitlab::Diff::File, file_path: nil)
|
|
|
|
|
|
|
|
allow(subject).to receive(:diff_files) { [readme_file, other_file, nil_path_file] }
|
|
|
|
expect(readme_file).to receive(:unfold_diff_lines).with(position)
|
|
|
|
|
|
|
|
subject.unfold_diff_files([position])
|
|
|
|
end
|
|
|
|
end
|