debian-mirror-gitlab/spec/uploaders/gitlab_uploader_spec.rb

183 lines
5 KiB
Ruby
Raw Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2019-12-04 20:38:33 +05:30
require 'spec_helper'
2017-09-10 17:25:29 +05:30
require 'carrierwave/storage/fog'
2020-07-28 23:09:34 +05:30
RSpec.describe GitlabUploader do
2017-09-10 17:25:29 +05:30
let(:uploader_class) { Class.new(described_class) }
2023-03-04 22:38:38 +05:30
subject(:uploader) { uploader_class.new(double) }
2017-09-10 17:25:29 +05:30
describe '#file_storage?' do
context 'when file storage is used' do
before do
uploader_class.storage(:file)
end
it { is_expected.to be_file_storage }
end
context 'when is remote storage' do
before do
uploader_class.storage(:fog)
end
it { is_expected.not_to be_file_storage }
end
end
describe '#file_cache_storage?' do
context 'when file storage is used' do
before do
2018-05-09 12:01:36 +05:30
expect(uploader_class).to receive(:cache_storage) { CarrierWave::Storage::File }
2017-09-10 17:25:29 +05:30
end
it { is_expected.to be_file_cache_storage }
end
context 'when is remote storage' do
before do
2018-05-09 12:01:36 +05:30
expect(uploader_class).to receive(:cache_storage) { CarrierWave::Storage::Fog }
2017-09-10 17:25:29 +05:30
end
it { is_expected.not_to be_file_cache_storage }
end
end
describe '#move_to_cache' do
it 'is true' do
expect(subject.move_to_cache).to eq(true)
end
end
describe '#move_to_store' do
it 'is true' do
expect(subject.move_to_store).to eq(true)
end
end
describe '#cache!' do
it 'moves the file from the working directory to the cache directory' do
# One to get the work dir, the other to remove it
2020-03-09 13:42:32 +05:30
expect(subject).to receive(:workfile_path).twice.and_call_original
2017-09-10 17:25:29 +05:30
# Test https://github.com/carrierwavesubject/carrierwave/blob/v1.0.0/lib/carrierwave/sanitized_file.rb#L200
expect(FileUtils).to receive(:mv).with(anything, /^#{subject.work_dir}/).and_call_original
expect(FileUtils).to receive(:mv).with(/^#{subject.work_dir}/, /#{subject.cache_dir}/).and_call_original
2018-11-08 19:23:39 +05:30
fixture = File.join('spec', 'fixtures', 'rails_sample.jpg')
2017-09-10 17:25:29 +05:30
subject.cache!(fixture_file_upload(fixture))
expect(subject.file.path).to match(/#{subject.cache_dir}/)
end
end
2018-11-18 11:00:15 +05:30
2019-12-21 20:55:43 +05:30
describe '#replace_file_without_saving!' do
it 'allows file to be replaced without triggering any callbacks' do
new_file = CarrierWave::SanitizedFile.new(Tempfile.new)
expect(subject).not_to receive(:with_callbacks)
subject.replace_file_without_saving!(new_file)
end
end
2018-11-18 11:00:15 +05:30
describe '#open' do
context 'when trace is stored in File storage' do
context 'when file exists' do
let(:file) do
fixture_file_upload('spec/fixtures/trace/sample_trace', 'text/plain')
end
before do
subject.store!(file)
end
it 'returns io stream' do
expect(subject.open).to be_a(IO)
end
it 'when passing block it yields' do
expect { |b| subject.open(&b) }.to yield_control
end
end
context 'when file does not exist' do
it 'returns nil' do
expect(subject.open).to be_nil
end
it 'when passing block it does not yield' do
expect { |b| subject.open(&b) }.not_to yield_control
end
end
end
context 'when trace is stored in Object storage' do
before do
allow(subject).to receive(:file_storage?) { false }
end
context 'when file exists' do
before do
allow(subject).to receive(:url) { 'http://object_storage.com/trace' }
end
it 'returns http io stream' do
expect(subject.open).to be_a(Gitlab::HttpIO)
end
it 'when passing block it yields' do
expect { |b| subject.open(&b) }.to yield_control.once
end
end
context 'when file does not exist' do
it 'returns nil' do
expect(subject.open).to be_nil
end
it 'when passing block it does not yield' do
expect { |b| subject.open(&b) }.not_to yield_control
end
end
end
2021-01-29 00:20:46 +05:30
describe '#url_or_file_path' do
let(:options) { { expire_at: 1.day.from_now } }
it 'returns url when in remote storage' do
expect(subject).to receive(:file_storage?).and_return(false)
expect(subject).to receive(:url).with(options).and_return("http://example.com")
expect(subject.url_or_file_path(options)).to eq("http://example.com")
end
it 'returns url when in remote storage' do
expect(subject).to receive(:file_storage?).and_return(true)
expect(subject).to receive(:path).and_return("/tmp/file")
expect(subject.url_or_file_path(options)).to eq("file:///tmp/file")
end
end
2018-11-18 11:00:15 +05:30
end
2022-07-23 23:45:48 +05:30
2023-03-04 22:38:38 +05:30
describe '#multi_read' do
let(:file) { fixture_file_upload('spec/fixtures/trace/sample_trace', 'text/plain') }
let(:byte_offsets) { [[4, 10], [17, 29]] }
subject { uploader.multi_read(byte_offsets) }
before do
uploader.store!(file)
end
it { is_expected.to eq(%w[Running gitlab-runner]) }
end
2022-07-23 23:45:48 +05:30
describe '.version' do
subject { uploader_class.version }
it { expect { subject }.to raise_error(RuntimeError, /not supported/) }
end
2017-09-10 17:25:29 +05:30
end