blob: 8ad4c2e644725579519572350116e69ab934e3cb (
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
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Packages::Rubygems::ExtractionWorker, type: :worker, feature_category: :package_registry do
describe '#perform' do
let_it_be(:package) { create(:rubygems_package, :processing) }
let(:package_file) { package.package_files.first }
let(:package_file_id) { package_file.id }
let(:package_name) { 'TempProject.TempPackage' }
let(:package_version) { '1.0.0' }
let(:job_args) { package_file_id }
subject { described_class.new.perform(*job_args) }
it 'processes the gem', :aggregate_failures do
expect { subject }
.to change { Packages::Package.count }.by(0)
.and change { Packages::PackageFile.count }.by(1)
expect(Packages::Package.last.id).to be(package.id)
expect(package.name).not_to be(package_name)
end
it 'handles a processing failure', :aggregate_failures do
expect(::Packages::Rubygems::ProcessGemService).to receive(:new)
.and_raise(::Packages::Rubygems::ProcessGemService::ExtractionError)
expect(Gitlab::ErrorTracking).to receive(:log_exception).with(
instance_of(::Packages::Rubygems::ProcessGemService::ExtractionError),
project_id: package.project_id
)
subject
expect(package.reload).to be_error
end
it 'handles processing an unaccounted for error', :aggregate_failures do
expect(::Packages::Rubygems::ProcessGemService).to receive(:new)
.and_raise(Zip::Error)
expect(Gitlab::ErrorTracking).to receive(:log_exception).with(
instance_of(Zip::Error),
project_id: package.project_id
)
subject
expect(package.reload).to be_error
end
context 'returns when there is no package file' do
let(:package_file_id) { 999999 }
it 'returns without action' do
expect(::Packages::Rubygems::ProcessGemService).not_to receive(:new)
expect { subject }
.to change { Packages::Package.count }.by(0)
.and change { Packages::PackageFile.count }.by(0)
end
end
end
end
|