Welcome to mirror list, hosted at ThFree Co, Russian Federation.

uploads_pipeline_spec.rb « pipelines « common « bulk_imports « lib « spec - gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: a3cc866a406f92a73c0a3c69d176d7a5d5d0cf71 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
# frozen_string_literal: true

require 'spec_helper'

RSpec.describe BulkImports::Common::Pipelines::UploadsPipeline do
  let_it_be(:tmpdir) { Dir.mktmpdir }
  let_it_be(:project) { create(:project) }
  let_it_be(:entity) { create(:bulk_import_entity, :project_entity, project: project, source_full_path: 'test') }
  let_it_be(:tracker) { create(:bulk_import_tracker, entity: entity) }
  let_it_be(:context) { BulkImports::Pipeline::Context.new(tracker) }
  let_it_be(:uploads_dir_path) { File.join(tmpdir, '72a497a02fe3ee09edae2ed06d390038') }
  let_it_be(:upload_file_path) { File.join(uploads_dir_path, 'upload.txt')}

  subject(:pipeline) { described_class.new(context) }

  before do
    stub_uploads_object_storage(FileUploader)

    FileUtils.mkdir_p(uploads_dir_path)
    FileUtils.touch(upload_file_path)
  end

  after do
    FileUtils.remove_entry(tmpdir) if Dir.exist?(tmpdir)
  end

  describe '#run' do
    it 'imports uploads into destination portable and removes tmpdir' do
      allow(Dir).to receive(:mktmpdir).with('bulk_imports').and_return(tmpdir)
      allow(pipeline).to receive(:extract).and_return(BulkImports::Pipeline::ExtractedData.new(data: [upload_file_path]))

      pipeline.run

      expect(project.uploads.map { |u| u.retrieve_uploader.filename }).to include('upload.txt')

      expect(Dir.exist?(tmpdir)).to eq(false)
    end
  end

  describe '#extract' do
    it 'downloads & extracts upload paths' do
      allow(Dir).to receive(:mktmpdir).and_return(tmpdir)
      expect(pipeline).to receive(:untar_zxf)
      file_download_service = instance_double("BulkImports::FileDownloadService")

      expect(BulkImports::FileDownloadService)
        .to receive(:new)
        .with(
          configuration: context.configuration,
          relative_url: "/projects/test/export_relations/download?relation=uploads",
          dir: tmpdir,
          filename: 'uploads.tar.gz')
        .and_return(file_download_service)

      expect(file_download_service).to receive(:execute)

      extracted_data = pipeline.extract(context)

      expect(extracted_data.data).to contain_exactly(uploads_dir_path, upload_file_path)
    end
  end

  describe '#load' do
    it 'creates a file upload' do
      expect { pipeline.load(context, upload_file_path) }.to change { project.uploads.count }.by(1)
    end

    context 'when dynamic path is nil' do
      it 'returns' do
        expect { pipeline.load(context, File.join(tmpdir, 'test')) }.not_to change { project.uploads.count }
      end
    end

    context 'when path is a directory' do
      it 'returns' do
        expect { pipeline.load(context, uploads_dir_path) }.not_to change { project.uploads.count }
      end
    end
  end
end