gitlab-ce/spec/models/packages/dependency_link_spec.rb

123 lines
4.2 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Packages::DependencyLink, type: :model, feature_category: :package_registry do
let_it_be(:package1) { create(:package) }
let_it_be(:package2) { create(:package) }
let_it_be(:dependency1) { create(:packages_dependency) }
let_it_be(:dependency2) { create(:packages_dependency) }
let_it_be(:dependency_link1) do
create(:packages_dependency_link, :dev_dependencies, package: package1, dependency: dependency1)
end
let_it_be(:dependency_link2) do
create(:packages_dependency_link, :dependencies, package: package1, dependency: dependency2)
end
let_it_be(:dependency_link3) do
create(:packages_dependency_link, :dependencies, package: package2, dependency: dependency1)
end
let_it_be(:dependency_link4) do
create(:packages_dependency_link, :dependencies, package: package2, dependency: dependency2)
end
describe 'relationships' do
it { is_expected.to belong_to(:package).inverse_of(:dependency_links) }
it { is_expected.to belong_to(:dependency).inverse_of(:dependency_links) }
it { is_expected.to have_one(:nuget_metadatum).inverse_of(:dependency_link) }
end
describe 'validations' do
subject { create(:packages_dependency_link) }
it { is_expected.to validate_presence_of(:package) }
it { is_expected.to validate_presence_of(:dependency) }
context 'package_id and package_dependency_id uniqueness for dependency_type' do
it 'is not valid' do
exisiting_link = subject
link = build(
:packages_dependency_link,
package: exisiting_link.package,
dependency: exisiting_link.dependency,
dependency_type: exisiting_link.dependency_type
)
expect(link).not_to be_valid
expect(link.errors.to_a).to include("Dependency type has already been taken")
end
end
end
context 'with multiple links' do
let_it_be(:link1) { create(:packages_dependency_link) }
let_it_be(:link2) { create(:packages_dependency_link, dependency: link1.dependency, dependency_type: :devDependencies) }
let_it_be(:link3) { create(:packages_dependency_link, dependency: link1.dependency, dependency_type: :bundleDependencies) }
subject { described_class }
describe '.with_dependency_type' do
it 'returns links of the given type' do
expect(subject.with_dependency_type(:bundleDependencies)).to eq([link3])
end
end
describe '.for_package' do
let_it_be(:link1) { create(:packages_dependency_link) }
let_it_be(:link2) { create(:packages_dependency_link, dependency: link1.dependency, dependency_type: :devDependencies) }
let_it_be(:link3) { create(:packages_dependency_link, dependency: link1.dependency, dependency_type: :bundleDependencies) }
it 'returns the link for the given package' do
expect(subject.for_package(link1.package)).to eq([link1])
end
end
end
describe '.dependency_ids_grouped_by_type' do
let(:packages) { Packages::Package.where(id: [package1.id, package2.id]) }
subject { described_class.dependency_ids_grouped_by_type(packages) }
it 'aggregates dependencies by type', :aggregate_failures do
result = Gitlab::Json.parse(subject.to_json)
expect(result.count).to eq(2)
expect(result).to include(
hash_including(
'package_id' => package1.id,
'dependency_ids_by_type' => {
'1' => [dependency2.id],
'2' => [dependency1.id]
}
),
hash_including(
'package_id' => package2.id,
'dependency_ids_by_type' => {
'1' => [dependency1.id, dependency2.id]
}
)
)
end
end
describe '.for_packages' do
let(:packages) { Packages::Package.where(id: package1.id) }
subject { described_class.for_packages(packages) }
it 'returns dependency links for selected packages' do
expect(subject).to contain_exactly(dependency_link1, dependency_link2)
end
end
describe '.select_dependency_id' do
subject { described_class.select_dependency_id }
it 'returns only dependency_id' do
expect(subject[0].attributes).to eq('dependency_id' => dependency1.id, 'id' => nil)
end
end
end