debian-mirror-gitlab/spec/services/packages/composer/create_package_service_spec.rb

123 lines
4 KiB
Ruby
Raw Normal View History

2020-07-28 23:09:34 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Packages::Composer::CreatePackageService do
include PackagesManagerApiSpecHelpers
let_it_be(:package_name) { 'composer-package-name' }
let_it_be(:json) { { name: package_name }.to_json }
2021-10-27 15:23:28 +05:30
let_it_be(:project) { create(:project, :custom_repo, files: { 'composer.json' => json }) }
2020-07-28 23:09:34 +05:30
let_it_be(:user) { create(:user) }
2021-09-30 23:02:18 +05:30
2020-07-28 23:09:34 +05:30
let(:params) do
{
branch: branch,
tag: tag
}
end
describe '#execute' do
let(:tag) { nil }
let(:branch) { nil }
subject { described_class.new(project, user, params).execute }
let(:created_package) { Packages::Package.composer.last }
context 'without an existing package' do
context 'with a branch' do
let(:branch) { project.repository.find_branch('master') }
it 'creates the package' do
expect { subject }
.to change { Packages::Package.composer.count }.by(1)
.and change { Packages::Composer::Metadatum.count }.by(1)
expect(created_package.name).to eq package_name
expect(created_package.version).to eq 'dev-master'
expect(created_package.composer_metadatum.target_sha).to eq branch.target
expect(created_package.composer_metadatum.composer_json.to_json).to eq json
end
2020-11-24 15:15:51 +05:30
it_behaves_like 'assigns the package creator' do
let(:package) { created_package }
end
2021-02-22 17:27:13 +05:30
it_behaves_like 'assigns build to package'
2021-03-11 19:13:27 +05:30
it_behaves_like 'assigns status to package'
2020-07-28 23:09:34 +05:30
end
context 'with a tag' do
let(:tag) { project.repository.find_tag('v1.2.3') }
2020-11-24 15:15:51 +05:30
before(:all) do
2020-07-28 23:09:34 +05:30
project.repository.add_tag(user, 'v1.2.3', 'master')
end
it 'creates the package' do
expect { subject }
.to change { Packages::Package.composer.count }.by(1)
.and change { Packages::Composer::Metadatum.count }.by(1)
expect(created_package.name).to eq package_name
expect(created_package.version).to eq '1.2.3'
end
2020-11-24 15:15:51 +05:30
it_behaves_like 'assigns the package creator' do
let(:package) { created_package }
end
2021-02-22 17:27:13 +05:30
it_behaves_like 'assigns build to package'
2021-03-11 19:13:27 +05:30
it_behaves_like 'assigns status to package'
2020-07-28 23:09:34 +05:30
end
end
context 'with an existing package' do
let(:branch) { project.repository.find_branch('master') }
context 'belonging to the same project' do
before do
described_class.new(project, user, params).execute
end
it 'does not create a new package' do
expect { subject }
.to change { Packages::Package.composer.count }.by(0)
.and change { Packages::Composer::Metadatum.count }.by(0)
end
end
context 'belonging to another project' do
2022-03-02 08:16:31 +05:30
let(:other_project) { create(:project)}
2020-07-28 23:09:34 +05:30
let!(:other_package) { create(:composer_package, name: package_name, version: 'dev-master', project: other_project) }
it 'fails with an error' do
expect { subject }
.to raise_error(/is already taken/)
end
2022-03-02 08:16:31 +05:30
context 'with pending_destruction package' do
let!(:other_package) { create(:composer_package, :pending_destruction, name: package_name, version: 'dev-master', project: other_project) }
it 'creates the package' do
expect { subject }
.to change { Packages::Package.composer.count }.by(1)
.and change { Packages::Composer::Metadatum.count }.by(1)
end
end
2020-07-28 23:09:34 +05:30
end
context 'same name but of different type' do
let(:other_project) { create(:project) }
let!(:other_package) { create(:package, name: package_name, version: 'dev-master', project: other_project) }
it 'creates the package' do
expect { subject }
.to change { Packages::Package.composer.count }.by(1)
.and change { Packages::Composer::Metadatum.count }.by(1)
end
end
end
end
end