2019-10-14 23:06:19 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-08-18 10:31:44 -04:00
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-06-24 11:08:50 -04:00
|
|
|
RSpec.describe AvatarUploader do
|
2018-02-02 08:59:43 -05:00
|
|
|
let(:model) { build_stubbed(:user) }
|
|
|
|
let(:uploader) { described_class.new(model, :avatar) }
|
|
|
|
let(:upload) { create(:upload, model: model) }
|
2016-08-18 10:31:44 -04:00
|
|
|
|
2018-02-02 08:59:43 -05:00
|
|
|
subject { uploader }
|
2017-06-07 23:32:38 -04:00
|
|
|
|
2018-02-02 08:59:43 -05:00
|
|
|
it_behaves_like 'builds correct paths',
|
|
|
|
store_dir: %r[uploads/-/system/user/avatar/],
|
|
|
|
upload_path: %r[uploads/-/system/user/avatar/],
|
|
|
|
absolute_path: %r[#{CarrierWave.root}/uploads/-/system/user/avatar/]
|
2017-06-07 23:32:38 -04:00
|
|
|
|
2018-02-02 08:59:43 -05:00
|
|
|
context "object_store is REMOTE" do
|
|
|
|
before do
|
|
|
|
stub_uploads_object_storage
|
2016-08-18 10:31:44 -04:00
|
|
|
end
|
2018-02-02 08:59:43 -05:00
|
|
|
|
|
|
|
include_context 'with storage', described_class::Store::REMOTE
|
|
|
|
|
|
|
|
it_behaves_like 'builds correct paths',
|
|
|
|
store_dir: %r[user/avatar/],
|
|
|
|
upload_path: %r[user/avatar/]
|
2016-08-18 10:31:44 -04:00
|
|
|
end
|
|
|
|
|
2018-02-02 08:59:43 -05:00
|
|
|
context "with a file" do
|
|
|
|
let(:project) { create(:project, :with_avatar) }
|
|
|
|
let(:uploader) { project.avatar }
|
|
|
|
let(:upload) { uploader.upload }
|
|
|
|
|
|
|
|
before do
|
|
|
|
stub_uploads_object_storage
|
2016-08-18 10:31:44 -04:00
|
|
|
end
|
2018-02-02 08:59:43 -05: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
|
2018-09-10 11:41:51 -04:00
|
|
|
|
|
|
|
it 'sets the right absolute path' do
|
|
|
|
storage_path = Gitlab.config.uploads.storage_path
|
|
|
|
absolute_path = File.join(storage_path, upload.path)
|
|
|
|
|
|
|
|
expect(uploader.absolute_path.scan(storage_path).size).to eq(1)
|
|
|
|
expect(uploader.absolute_path).to eq(absolute_path)
|
|
|
|
end
|
2016-08-18 10:31:44 -04:00
|
|
|
end
|
2020-01-02 16:07:38 -05:00
|
|
|
|
2020-03-12 14:09:28 -04:00
|
|
|
context 'accept whitelist file content type' do
|
|
|
|
# We need to feed through a valid path, but we force the parsed mime type
|
|
|
|
# in a stub below so we can set any path.
|
|
|
|
let_it_be(:path) { File.join('spec', 'fixtures', 'video_sample.mp4') }
|
|
|
|
|
|
|
|
where(:mime_type) { described_class::MIME_WHITELIST }
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
include_context 'force content type detection to mime_type'
|
2020-01-02 16:07:38 -05:00
|
|
|
|
2020-03-12 14:09:28 -04:00
|
|
|
it_behaves_like 'accepted carrierwave upload'
|
2020-01-02 16:07:38 -05:00
|
|
|
end
|
|
|
|
end
|
2020-03-12 14:09:28 -04:00
|
|
|
|
|
|
|
context 'upload non-whitelisted file content type' do
|
|
|
|
let_it_be(:path) { File.join('spec', 'fixtures', 'sanitized.svg') }
|
|
|
|
|
|
|
|
it_behaves_like 'denied carrierwave upload'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'upload misnamed non-whitelisted file content type' do
|
|
|
|
let_it_be(:path) { File.join('spec', 'fixtures', 'not_a_png.png') }
|
|
|
|
|
|
|
|
it_behaves_like 'denied carrierwave upload'
|
|
|
|
end
|
2016-08-18 10:31:44 -04:00
|
|
|
end
|