2019-10-12 21:52:04 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Backup::Uploads do
|
2019-07-07 11:18:12 +05:30
|
|
|
let(:progress) { StringIO.new }
|
2020-01-01 13:55:28 +05:30
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
subject(:backup) { described_class.new(progress) }
|
|
|
|
|
|
|
|
describe '#initialize' do
|
|
|
|
it 'uses the correct upload dir' do
|
|
|
|
Dir.mktmpdir do |tmpdir|
|
|
|
|
FileUtils.mkdir_p("#{tmpdir}/uploads")
|
|
|
|
|
|
|
|
allow(Gitlab.config.uploads).to receive(:storage_path) { tmpdir }
|
|
|
|
|
|
|
|
expect(backup.app_files_dir).to eq("#{tmpdir}/uploads")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2020-11-24 15:15:51 +05:30
|
|
|
|
|
|
|
describe '#dump' do
|
|
|
|
before do
|
|
|
|
allow(File).to receive(:realpath).with('/var/uploads').and_return('/var/uploads')
|
|
|
|
allow(File).to receive(:realpath).with('/var/uploads/..').and_return('/var')
|
|
|
|
allow(Gitlab.config.uploads).to receive(:storage_path) { '/var' }
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'uses the correct upload dir' do
|
|
|
|
expect(backup.app_files_dir).to eq('/var/uploads')
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'excludes tmp from backup tar' do
|
|
|
|
expect(backup).to receive(:tar).and_return('blabla-tar')
|
2021-01-29 00:20:46 +05:30
|
|
|
expect(backup).to receive(:run_pipeline!).with([%w(blabla-tar --exclude=lost+found --exclude=./tmp -C /var/uploads -cf - .), 'gzip -c -1'], any_args).and_return([[true, true], ''])
|
|
|
|
expect(backup).to receive(:pipeline_succeeded?).and_return(true)
|
2020-11-24 15:15:51 +05:30
|
|
|
backup.dump
|
|
|
|
end
|
|
|
|
end
|
2019-07-07 11:18:12 +05:30
|
|
|
end
|