diff options
Diffstat (limited to 'spec/services/packages/debian')
3 files changed, 201 insertions, 0 deletions
diff --git a/spec/services/packages/debian/create_package_file_service_spec.rb b/spec/services/packages/debian/create_package_file_service_spec.rb new file mode 100644 index 00000000000..74b97a4f941 --- /dev/null +++ b/spec/services/packages/debian/create_package_file_service_spec.rb @@ -0,0 +1,106 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Packages::Debian::CreatePackageFileService do + include WorkhorseHelpers + + let_it_be(:package) { create(:debian_incoming, without_package_files: true) } + + describe '#execute' do + let(:file_name) { 'libsample0_1.2.3~alpha2_amd64.deb' } + let(:fixture_path) { "spec/fixtures/packages/debian/#{file_name}" } + + let(:params) do + { + file: file, + file_name: file_name, + file_sha1: '54321', + file_md5: '12345' + }.with_indifferent_access + end + + let(:service) { described_class.new(package, params) } + + subject(:package_file) { service.execute } + + shared_examples 'a valid deb' do + it 'creates a new package file', :aggregate_failures do + expect(package_file).to be_valid + expect(package_file.file.read).to start_with('!<arch>') + expect(package_file.size).to eq(1124) + expect(package_file.file_name).to eq(file_name) + expect(package_file.file_sha1).to eq('54321') + expect(package_file.file_sha256).to eq('543212345') + expect(package_file.file_md5).to eq('12345') + expect(package_file.debian_file_metadatum).to be_valid + expect(package_file.debian_file_metadatum.file_type).to eq('unknown') + expect(package_file.debian_file_metadatum.architecture).to be_nil + expect(package_file.debian_file_metadatum.fields).to be_nil + end + end + + context 'with temp file' do + let!(:file) do + upload_path = ::Packages::PackageFileUploader.workhorse_local_upload_path + file_path = upload_path + '/' + file_name + + FileUtils.mkdir_p(upload_path) + File.write(file_path, File.read(fixture_path)) + + UploadedFile.new(file_path, filename: File.basename(file_path), sha256: '543212345') + end + + it_behaves_like 'a valid deb' + end + + context 'with remote file' do + let!(:fog_connection) do + stub_package_file_object_storage(direct_upload: true) + end + + before do + allow_next_instance_of(UploadedFile) do |uploaded_file| + allow(uploaded_file).to receive(:sha256).and_return('543212345') + end + end + + let(:tmp_object) do + fog_connection.directories.new(key: 'packages').files.create( # rubocop:disable Rails/SaveBang + key: "tmp/uploads/#{file_name}", + body: File.read(fixture_path) + ) + end + + let!(:file) { fog_to_uploaded_file(tmp_object) } + + it_behaves_like 'a valid deb' + end + + context 'package is missing' do + let(:package) { nil } + let(:params) { {} } + + it 'raises an error' do + expect { subject.execute }.to raise_error(ArgumentError, 'Invalid package') + end + end + + context 'params is empty' do + let(:params) { {} } + + it 'raises an error' do + expect { subject.execute }.to raise_error(ActiveRecord::RecordInvalid) + end + end + + context 'file is missing' do + let(:file_name) { 'libsample0_1.2.3~alpha2_amd64.deb' } + let(:file) { nil } + + it 'raises an error' do + expect { subject.execute }.to raise_error(ActiveRecord::RecordInvalid) + end + end + end +end diff --git a/spec/services/packages/debian/extract_metadata_service_spec.rb b/spec/services/packages/debian/extract_metadata_service_spec.rb new file mode 100644 index 00000000000..0aa9a67b263 --- /dev/null +++ b/spec/services/packages/debian/extract_metadata_service_spec.rb @@ -0,0 +1,59 @@ +# frozen_string_literal: true +require 'spec_helper' + +RSpec.describe Packages::Debian::ExtractMetadataService do + let(:service) { described_class.new(package_file) } + + subject { service.execute } + + RSpec.shared_context 'Debian ExtractMetadata Service' do |trait| + let(:package_file) { create(:debian_package_file, trait) } + end + + RSpec.shared_examples 'Test Debian ExtractMetadata Service' do |expected_file_type, expected_architecture, expected_fields| + it "returns file_type #{expected_file_type.inspect}" do + expect(subject[:file_type]).to eq(expected_file_type) + end + + it "returns architecture #{expected_architecture.inspect}" do + expect(subject[:architecture]).to eq(expected_architecture) + end + + it "returns fields #{expected_fields.nil? ? '' : 'including '}#{expected_fields.inspect}" do + if expected_fields.nil? + expect(subject[:fields]).to be_nil + else + expect(subject[:fields]).to include(**expected_fields) + end + end + end + + using RSpec::Parameterized::TableSyntax + + where(:case_name, :trait, :expected_file_type, :expected_architecture, :expected_fields) do + 'with invalid' | :invalid | :unknown | nil | nil + 'with source' | :source | :source | nil | nil + 'with dsc' | :dsc | :dsc | nil | { 'Binary': 'sample-dev, libsample0, sample-udeb' } + 'with deb' | :deb | :deb | 'amd64' | { 'Multi-Arch': 'same' } + 'with udeb' | :udeb | :udeb | 'amd64' | { 'Package': 'sample-udeb' } + 'with buildinfo' | :buildinfo | :buildinfo | nil | { 'Architecture': 'amd64 source', 'Build-Architecture': 'amd64' } + 'with changes' | :changes | :changes | nil | { 'Architecture': 'source amd64', 'Binary': 'libsample0 sample-dev sample-udeb' } + end + + with_them do + include_context 'Debian ExtractMetadata Service', params[:trait] do + it_behaves_like 'Test Debian ExtractMetadata Service', + params[:expected_file_type], + params[:expected_architecture], + params[:expected_fields] + end + end + + context 'with invalid package file' do + let(:package_file) { create(:conan_package_file) } + + it 'raise error' do + expect { subject }.to raise_error(described_class::ExtractionError, 'invalid package file') + end + end +end diff --git a/spec/services/packages/debian/get_or_create_incoming_service_spec.rb b/spec/services/packages/debian/get_or_create_incoming_service_spec.rb new file mode 100644 index 00000000000..ab99b091246 --- /dev/null +++ b/spec/services/packages/debian/get_or_create_incoming_service_spec.rb @@ -0,0 +1,36 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe Packages::Debian::GetOrCreateIncomingService do + let_it_be(:project) { create(:project) } + let_it_be(:user) { create(:user) } + + subject(:service) { described_class.new(project, user) } + + describe '#execute' do + subject(:package) { service.execute } + + context 'run once' do + it 'creates a new package', :aggregate_failures do + expect(package).to be_valid + expect(package.project_id).to eq(project.id) + expect(package.creator_id).to eq(user.id) + expect(package.name).to eq('incoming') + expect(package.version).to be_nil + expect(package.package_type).to eq('debian') + expect(package.debian_incoming?).to be_truthy + end + + it_behaves_like 'assigns the package creator' + end + + context 'run twice' do + let!(:package2) { service.execute } + + it 'returns the same object' do + expect(package2.id).to eq(package.id) + end + end + end +end |