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

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

86 lines
2.5 KiB
Ruby
Raw Permalink Normal View History

2019-12-21 20:55:43 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2020-07-28 23:09:34 +05:30
RSpec.describe PersonalFileUploader do
2018-03-17 18:26:18 +05:30
let(:model) { create(:personal_snippet) }
let(:uploader) { described_class.new(model) }
let(:upload) { create(:upload, :personal_snippet_upload) }
2020-03-07 23:17:34 +05:30
let(:secret) { SecureRandom.hex }
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
subject { uploader }
2017-08-17 22:00:37 +05:30
2019-07-31 22:56:46 +05:30
shared_examples '#base_dir' do
2018-05-09 12:01:36 +05:30
before do
2020-03-07 23:17:34 +05:30
subject.instance_variable_set(:@secret, secret)
2018-05-09 12:01:36 +05:30
end
2019-07-31 22:56:46 +05:30
it 'is prefixed with uploads/-/system' do
allow(uploader).to receive(:file).and_return(double(extension: 'txt', filename: 'file_name'))
2019-03-02 22:35:43 +05:30
2019-07-31 22:56:46 +05:30
expect(described_class.base_dir(model)).to eq("uploads/-/system/personal_snippet/#{model.id}")
2019-02-15 15:39:39 +05:30
end
2018-05-09 12:01:36 +05:30
end
2019-07-31 22:56:46 +05:30
shared_examples '#to_h' do
2018-03-17 18:26:18 +05:30
before do
2020-03-07 23:17:34 +05:30
subject.instance_variable_set(:@secret, secret)
2018-03-17 18:26:18 +05:30
end
2017-08-17 22:00:37 +05:30
2018-03-17 18:26:18 +05:30
it 'is correct' do
2017-08-17 22:00:37 +05:30
allow(uploader).to receive(:file).and_return(double(extension: 'txt', filename: 'file_name'))
2020-03-07 23:17:34 +05:30
expected_url = "/uploads/-/system/personal_snippet/#{model.id}/#{secret}/file_name"
2017-08-17 22:00:37 +05:30
expect(uploader.to_h).to eq(
alt: 'file_name',
url: expected_url,
markdown: "[file_name](#{expected_url})"
)
end
end
2018-05-09 12:01:36 +05:30
2019-07-31 22:56:46 +05:30
describe '#upload_paths' do
it 'builds correct paths for both local and remote storage' do
paths = uploader.upload_paths('test.jpg')
2023-03-04 22:38:38 +05:30
expect(paths.first).to match(%r[\h+/test.jpg])
expect(paths.second).to match(%r[^personal_snippet/\d+/\h+/test.jpg])
2019-07-31 22:56:46 +05:30
end
end
context 'object_store is LOCAL' do
it_behaves_like 'builds correct paths',
2023-06-20 00:43:36 +05:30
store_dir: %r[uploads/-/system/personal_snippet/\d+/\h+],
upload_path: %r[\h+/\S+],
absolute_path: %r[#{CarrierWave.root}/uploads/-/system/personal_snippet/\d+/\h+/\S+$]
2019-07-31 22:56:46 +05:30
it_behaves_like '#base_dir'
it_behaves_like '#to_h'
end
context "object_store is REMOTE" do
before do
stub_uploads_object_storage
end
include_context 'with storage', described_class::Store::REMOTE
it_behaves_like 'builds correct paths',
2023-06-20 00:43:36 +05:30
store_dir: %r[\d+/\h+],
upload_path: %r[^personal_snippet/\d+/\h+/<filename>]
2019-07-31 22:56:46 +05:30
it_behaves_like '#base_dir'
it_behaves_like '#to_h'
end
2018-05-09 12:01:36 +05:30
describe "#migrate!" do
before do
2018-11-08 19:23:39 +05:30
uploader.store!(fixture_file_upload('spec/fixtures/doc_sample.txt'))
2018-05-09 12:01:36 +05:30
stub_uploads_object_storage
end
it_behaves_like "migrates", to_store: described_class::Store::REMOTE
it_behaves_like "migrates", from_store: described_class::Store::REMOTE, to_store: described_class::Store::LOCAL
end
2017-08-17 22:00:37 +05:30
end