2019-10-15 03:06:19 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-12-06 11:36:11 +00:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 15:08:50 +00:00
|
|
|
RSpec.describe NamespaceFileUploader do
|
2017-12-06 11:36:11 +00:00
|
|
|
let(:group) { build_stubbed(:group) }
|
|
|
|
let(:uploader) { described_class.new(group) }
|
2018-02-02 13:59:43 +00:00
|
|
|
let(:upload) { create(:upload, :namespace_upload, model: group) }
|
2018-12-09 19:16:09 +00:00
|
|
|
let(:identifier) { %r{\h+/\S+} }
|
2018-02-02 13:59:43 +00:00
|
|
|
|
|
|
|
subject { uploader }
|
2017-12-06 11:36:11 +00:00
|
|
|
|
2018-12-09 19:16:09 +00:00
|
|
|
it_behaves_like 'builds correct paths' do
|
|
|
|
let(:patterns) do
|
|
|
|
{
|
|
|
|
store_dir: %r[uploads/-/system/namespace/\d+],
|
|
|
|
upload_path: identifier,
|
|
|
|
absolute_path: %r[#{CarrierWave.root}/uploads/-/system/namespace/\d+/#{identifier}]
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
2018-02-02 13:59:43 +00:00
|
|
|
|
|
|
|
context "object_store is REMOTE" do
|
|
|
|
before do
|
|
|
|
stub_uploads_object_storage
|
2017-12-06 11:36:11 +00:00
|
|
|
end
|
|
|
|
|
2018-02-02 13:59:43 +00:00
|
|
|
include_context 'with storage', described_class::Store::REMOTE
|
2017-12-06 11:36:11 +00:00
|
|
|
|
2018-12-09 19:16:09 +00:00
|
|
|
it_behaves_like 'builds correct paths' do
|
|
|
|
let(:patterns) do
|
|
|
|
{
|
|
|
|
store_dir: %r[namespace/\d+/\h+],
|
|
|
|
upload_path: identifier
|
|
|
|
}
|
|
|
|
end
|
|
|
|
end
|
2018-02-02 13:59:43 +00:00
|
|
|
end
|
|
|
|
|
2020-02-06 21:08:48 +00:00
|
|
|
describe '.base_dir' do
|
2018-08-20 12:46:22 +00:00
|
|
|
it 'returns local storage base_dir without store param' do
|
|
|
|
expect(described_class.base_dir(group)).to eq("uploads/-/system/namespace/#{group.id}")
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns local storage base_dir when store param is Store::LOCAL' do
|
|
|
|
expect(described_class.base_dir(group, ObjectStorage::Store::LOCAL)).to eq("uploads/-/system/namespace/#{group.id}")
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'returns remote base_dir when store param is Store::REMOTE' do
|
|
|
|
expect(described_class.base_dir(group, ObjectStorage::Store::REMOTE)).to eq("namespace/#{group.id}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-09-10 17:03:33 +00:00
|
|
|
describe '#workhorse_local_upload_path' do
|
|
|
|
it 'returns the correct path in uploads directory' do
|
|
|
|
expect(described_class.workhorse_local_upload_path).to end_with('/uploads/tmp/uploads')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2018-02-02 13:59:43 +00:00
|
|
|
describe "#migrate!" do
|
|
|
|
before do
|
2018-06-05 21:18:06 +00:00
|
|
|
uploader.store!(fixture_file_upload(File.join('spec/fixtures/doc_sample.txt')))
|
2018-02-02 13:59:43 +00:00
|
|
|
stub_uploads_object_storage
|
2017-12-06 11:36:11 +00:00
|
|
|
end
|
2018-02-02 13:59:43 +00:00
|
|
|
|
|
|
|
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
|
2017-12-06 11:36:11 +00:00
|
|
|
end
|
2018-10-29 09:05:47 +00:00
|
|
|
|
|
|
|
describe 'copy_to' do
|
|
|
|
let(:group) { create(:group) }
|
|
|
|
let(:moved) { described_class.copy_to(subject, group) }
|
|
|
|
|
|
|
|
shared_examples 'returns a valid uploader' do
|
|
|
|
it 'generates a new secret' do
|
|
|
|
expect(subject).to be
|
|
|
|
expect(described_class).to receive(:generate_secret).once.and_call_original
|
|
|
|
expect(moved).to be
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates new upload correctly' do
|
|
|
|
upload = moved.upload
|
|
|
|
|
|
|
|
expect(upload).not_to eq(subject.upload)
|
|
|
|
expect(upload.model).to eq(group)
|
|
|
|
expect(upload.uploader).to eq('NamespaceFileUploader')
|
|
|
|
expect(upload.secret).not_to eq(subject.upload.secret)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'copies the file' do
|
|
|
|
expect(subject.file).to exist
|
|
|
|
expect(moved.file).to exist
|
|
|
|
expect(subject.file).not_to eq(moved.file)
|
|
|
|
expect(subject.object_store).to eq(moved.object_store)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'files are stored locally' do
|
|
|
|
before do
|
|
|
|
subject.store!(fixture_file_upload('spec/fixtures/dk.png'))
|
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'returns a valid uploader'
|
|
|
|
|
|
|
|
it 'copies the file to the correct location' do
|
|
|
|
expect(moved.upload.path).to eq("#{moved.upload.secret}/dk.png")
|
|
|
|
expect(moved.file.path).to end_with("system/namespace/#{group.id}/#{moved.upload.secret}/dk.png")
|
|
|
|
expect(moved.filename).to eq('dk.png')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'files are stored remotely' do
|
|
|
|
before do
|
|
|
|
stub_uploads_object_storage
|
|
|
|
subject.store!(fixture_file_upload('spec/fixtures/dk.png'))
|
|
|
|
subject.migrate!(ObjectStorage::Store::REMOTE)
|
|
|
|
end
|
|
|
|
|
|
|
|
include_examples 'returns a valid uploader'
|
|
|
|
|
|
|
|
it 'copies the file to the correct location' do
|
|
|
|
expect(moved.file.path).to eq("namespace/#{group.id}/#{moved.upload.secret}/dk.png")
|
|
|
|
expect(moved.filename).to eq('dk.png')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-12-06 11:36:11 +00:00
|
|
|
end
|