2019-12-21 20:55:43 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
describe JobArtifactUploader do
|
2018-05-09 12:01:36 +05:30
|
|
|
let(:store) { described_class::Store::LOCAL }
|
|
|
|
let(:job_artifact) { create(:ci_job_artifact, file_store: store) }
|
2018-03-17 18:26:18 +05:30
|
|
|
let(:uploader) { described_class.new(job_artifact, :file) }
|
|
|
|
|
|
|
|
subject { uploader }
|
|
|
|
|
|
|
|
it_behaves_like "builds correct paths",
|
|
|
|
store_dir: %r[\h{2}/\h{2}/\h{64}/\d{4}_\d{1,2}_\d{1,2}/\d+/\d+\z],
|
|
|
|
cache_dir: %r[artifacts/tmp/cache],
|
|
|
|
work_dir: %r[artifacts/tmp/work]
|
|
|
|
|
2018-05-09 12:01:36 +05:30
|
|
|
context "object store is REMOTE" do
|
|
|
|
before do
|
|
|
|
stub_artifacts_object_storage
|
|
|
|
end
|
|
|
|
|
|
|
|
include_context 'with storage', described_class::Store::REMOTE
|
|
|
|
|
|
|
|
it_behaves_like "builds correct paths",
|
|
|
|
store_dir: %r[\h{2}/\h{2}/\h{64}/\d{4}_\d{1,2}_\d{1,2}/\d+/\d+\z]
|
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
context 'file is stored in valid local_path' do
|
|
|
|
let(:file) do
|
2018-11-08 19:23:39 +05:30
|
|
|
fixture_file_upload('spec/fixtures/ci_build_artifacts.zip', 'application/zip')
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
before do
|
|
|
|
uploader.store!(file)
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { uploader.file.path }
|
|
|
|
|
|
|
|
it { is_expected.to start_with("#{uploader.root}/#{uploader.class.base_dir}") }
|
|
|
|
it { is_expected.to include("/#{job_artifact.created_at.utc.strftime('%Y_%m_%d')}/") }
|
|
|
|
it { is_expected.to include("/#{job_artifact.job_id}/#{job_artifact.id}/") }
|
|
|
|
it { is_expected.to end_with("ci_build_artifacts.zip") }
|
|
|
|
end
|
2018-05-09 12:01:36 +05:30
|
|
|
|
2018-11-20 20:47:30 +05:30
|
|
|
describe '#dynamic_segment' do
|
|
|
|
let(:uploaded_content) { File.binread(Rails.root + 'spec/fixtures/ci_build_artifacts.zip') }
|
|
|
|
let(:model) { uploader.model }
|
|
|
|
|
|
|
|
shared_examples_for 'Read file from legacy path' do
|
|
|
|
it 'store_path returns the legacy path' do
|
|
|
|
expect(model.file.store_path).to eq(File.join(model.created_at.utc.strftime('%Y_%m'), model.project_id.to_s, model.job_id.to_s, 'ci_build_artifacts.zip'))
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'has exactly the same content' do
|
|
|
|
expect(::File.binread(model.file.path)).to eq(uploaded_content)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
shared_examples_for 'Read file from hashed path' do
|
|
|
|
it 'store_path returns hashed path' do
|
|
|
|
expect(model.file.store_path).to eq(File.join(disk_hash[0..1], disk_hash[2..3], disk_hash, creation_date, model.job_id.to_s, model.id.to_s, 'ci_build_artifacts.zip'))
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'has exactly the same content' do
|
|
|
|
expect(::File.binread(model.file.path)).to eq(uploaded_content)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when a job artifact is stored in legacy_path' do
|
|
|
|
let(:job_artifact) { create(:ci_job_artifact, :legacy_archive) }
|
|
|
|
|
|
|
|
it_behaves_like 'Read file from legacy path'
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when the artifact file is stored in hashed_path' do
|
|
|
|
let(:job_artifact) { create(:ci_job_artifact, :archive) }
|
|
|
|
let(:disk_hash) { Digest::SHA2.hexdigest(model.project_id.to_s) }
|
|
|
|
let(:creation_date) { model.created_at.utc.strftime('%Y_%m_%d') }
|
|
|
|
|
|
|
|
it_behaves_like 'Read file from hashed path'
|
|
|
|
|
|
|
|
context 'when file_location column is empty' do
|
|
|
|
before do
|
|
|
|
job_artifact.update_column(:file_location, nil)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'Read file from hashed path'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
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/trace/sample_trace'))
|
2018-05-09 12:01:36 +05:30
|
|
|
stub_artifacts_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
|
2018-03-17 18:26:18 +05:30
|
|
|
end
|