2019-07-07 11:18:12 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe DiffViewer::ServerSide do
|
2020-03-13 15:44:24 +05:30
|
|
|
let_it_be(:project) { create(:project, :repository) }
|
2021-09-30 23:02:18 +05:30
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
let(:commit) { project.commit_by(oid: '570e7b2abdd848b95f2f578043fc23bd6f6fd24d') }
|
|
|
|
let!(:diff_file) { commit.diffs.diff_file_with_new_path('files/ruby/popen.rb') }
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
let(:viewer_class) do
|
|
|
|
Class.new(DiffViewer::Base) do
|
|
|
|
include DiffViewer::ServerSide
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { viewer_class.new(diff_file) }
|
|
|
|
|
|
|
|
describe '#prepare!' do
|
2022-11-25 23:54:43 +05:30
|
|
|
before do
|
|
|
|
stub_feature_flags(disable_load_entire_blob_for_diff_viewer: feature_flag_enabled)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the disable_load_entire_blob_for_diff_viewer flag is disabled' do
|
|
|
|
let(:feature_flag_enabled) { false }
|
2017-09-10 17:25:29 +05:30
|
|
|
|
2022-11-25 23:54:43 +05:30
|
|
|
it 'loads all diff file data' do
|
|
|
|
subject
|
|
|
|
expect(diff_file).to receive_message_chain(:old_blob, :load_all_data!)
|
|
|
|
expect(diff_file).to receive_message_chain(:new_blob, :load_all_data!)
|
|
|
|
subject.prepare!
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the disable_load_entire_blob_for_diff_viewer flag is enabled' do
|
|
|
|
let(:feature_flag_enabled) { true }
|
|
|
|
|
|
|
|
it 'does not load file data' do
|
|
|
|
subject
|
|
|
|
expect(diff_file).not_to receive(:old_blob)
|
|
|
|
expect(diff_file).not_to receive(:new_blob)
|
|
|
|
subject.prepare!
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#render_error' do
|
|
|
|
context 'when the diff file is stored externally' do
|
|
|
|
before do
|
|
|
|
allow(diff_file).to receive(:stored_externally?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'return :server_side_but_stored_externally' do
|
|
|
|
expect(subject.render_error).to eq(:server_side_but_stored_externally)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2019-02-15 15:39:39 +05:30
|
|
|
|
|
|
|
describe '#render_error_reason' do
|
|
|
|
context 'when the diff file is stored externally' do
|
|
|
|
before do
|
|
|
|
allow(diff_file).to receive(:stored_externally?).and_return(true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns error message if stored in LFS' do
|
|
|
|
allow(diff_file).to receive(:external_storage).and_return(:lfs)
|
|
|
|
|
|
|
|
expect(subject.render_error_message).to include('it is stored in LFS')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns error message if stored externally' do
|
|
|
|
allow(diff_file).to receive(:external_storage).and_return(:foo)
|
|
|
|
|
|
|
|
expect(subject.render_error_message).to include('it is stored externally')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|