2018-05-09 12:01:36 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe LfsObject do
|
|
|
|
describe '#local_store?' do
|
|
|
|
it 'returns true when file_store is equal to LfsObjectUploader::Store::LOCAL' do
|
|
|
|
subject.file_store = LfsObjectUploader::Store::LOCAL
|
|
|
|
|
|
|
|
expect(subject.local_store?).to eq true
|
|
|
|
end
|
|
|
|
|
2018-12-13 13:39:08 +05:30
|
|
|
it 'returns false when file_store is equal to LfsObjectUploader::Store::REMOTE' do
|
2018-05-09 12:01:36 +05:30
|
|
|
subject.file_store = LfsObjectUploader::Store::REMOTE
|
|
|
|
|
|
|
|
expect(subject.local_store?).to eq false
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#schedule_background_upload' do
|
|
|
|
before do
|
|
|
|
stub_lfs_setting(enabled: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { create(:lfs_object, :with_file) }
|
|
|
|
|
|
|
|
context 'when object storage is disabled' do
|
|
|
|
before do
|
|
|
|
stub_lfs_object_storage(enabled: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'does not schedule the migration' do
|
|
|
|
expect(ObjectStorage::BackgroundMoveWorker).not_to receive(:perform_async)
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when object storage is enabled' do
|
|
|
|
context 'when background upload is enabled' do
|
|
|
|
context 'when is licensed' do
|
|
|
|
before do
|
|
|
|
stub_lfs_object_storage(background_upload: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules the model for migration' do
|
|
|
|
expect(ObjectStorage::BackgroundMoveWorker)
|
|
|
|
.to receive(:perform_async)
|
|
|
|
.with('LfsObjectUploader', described_class.name, :file, kind_of(Numeric))
|
|
|
|
.once
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules the model for migration once' do
|
|
|
|
expect(ObjectStorage::BackgroundMoveWorker)
|
|
|
|
.to receive(:perform_async)
|
|
|
|
.with('LfsObjectUploader', described_class.name, :file, kind_of(Numeric))
|
|
|
|
.once
|
|
|
|
|
|
|
|
create(:lfs_object, :with_file)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when background upload is disabled' do
|
|
|
|
before do
|
|
|
|
stub_lfs_object_storage(background_upload: false)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'schedules the model for migration' do
|
|
|
|
expect(ObjectStorage::BackgroundMoveWorker).not_to receive(:perform_async)
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe 'file is being stored' do
|
|
|
|
let(:lfs_object) { create(:lfs_object, :with_file) }
|
|
|
|
|
|
|
|
context 'when existing object has local store' do
|
|
|
|
it 'is stored locally' do
|
|
|
|
expect(lfs_object.file_store).to be(ObjectStorage::Store::LOCAL)
|
|
|
|
expect(lfs_object.file).to be_file_storage
|
|
|
|
expect(lfs_object.file.object_store).to eq(ObjectStorage::Store::LOCAL)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when direct upload is enabled' do
|
|
|
|
before do
|
|
|
|
stub_lfs_object_storage(direct_upload: true)
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when file is stored' do
|
|
|
|
it 'is stored remotely' do
|
|
|
|
expect(lfs_object.file_store).to eq(ObjectStorage::Store::REMOTE)
|
|
|
|
expect(lfs_object.file).not_to be_file_storage
|
|
|
|
expect(lfs_object.file.object_store).to eq(ObjectStorage::Store::REMOTE)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|