summaryrefslogtreecommitdiff
path: root/spec/lib/gitlab/discussions_diff/file_collection_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/lib/gitlab/discussions_diff/file_collection_spec.rb')
-rw-r--r--spec/lib/gitlab/discussions_diff/file_collection_spec.rb35
1 files changed, 35 insertions, 0 deletions
diff --git a/spec/lib/gitlab/discussions_diff/file_collection_spec.rb b/spec/lib/gitlab/discussions_diff/file_collection_spec.rb
new file mode 100644
index 00000000000..193bcd34180
--- /dev/null
+++ b/spec/lib/gitlab/discussions_diff/file_collection_spec.rb
@@ -0,0 +1,35 @@
+require 'spec_helper'
+
+describe Gitlab::DiscussionsDiff::FileCollection do
+ let(:merge_request) { create(:merge_request) }
+ let!(:diff_note_a) { create(:diff_note_on_merge_request, project: merge_request.project, noteable: merge_request) }
+ let!(:diff_note_b) { create(:diff_note_on_merge_request, project: merge_request.project, noteable: merge_request) }
+ let(:note_diff_file_a) { diff_note_a.note_diff_file }
+ let(:note_diff_file_b) { diff_note_b.note_diff_file }
+
+ let(:subject) { described_class.new([note_diff_file_a, note_diff_file_b]) }
+
+ describe '#preload_all', :clean_gitlab_redis_shared_state do
+ it 'writes uncached diffs highlight' do
+ file_a_caching_content = diff_note_a.diff_file.highlighted_diff_lines.map(&:to_hash)
+ file_b_caching_content = diff_note_b.diff_file.highlighted_diff_lines.map(&:to_hash)
+
+ expect(Gitlab::DiscussionsDiff::HighlightCache)
+ .to receive(:write_multiple)
+ .with([[note_diff_file_a.id, file_a_caching_content],
+ [note_diff_file_b.id, file_b_caching_content]])
+ .and_call_original
+
+ subject.preload_all
+ end
+
+ it 'preloaded diff files have @highlighted_diff_lines' do
+ subject.preload_all
+
+ diff_file = subject.find_by_id(note_diff_file_a.id)
+
+ expect(diff_file.instance_variable_get(:@highlighted_diff_lines))
+ .to all(be_a(Gitlab::Diff::Line))
+ end
+ end
+end