diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2023-03-23 18:11:27 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2023-03-23 18:11:27 +0300 |
commit | 003d7f2a09668af85f94e48ed49d60862b96d8f8 (patch) | |
tree | 10f9baf4674416a5a7ca376bcc651973a56917b5 /spec/presenters/packages | |
parent | e10ea43772b9a6be150a074be7e26bfd6fa0380e (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/presenters/packages')
-rw-r--r-- | spec/presenters/packages/npm/package_presenter_spec.rb | 161 |
1 files changed, 18 insertions, 143 deletions
diff --git a/spec/presenters/packages/npm/package_presenter_spec.rb b/spec/presenters/packages/npm/package_presenter_spec.rb index 4fa469c7cd2..fe4773a9cad 100644 --- a/spec/presenters/packages/npm/package_presenter_spec.rb +++ b/spec/presenters/packages/npm/package_presenter_spec.rb @@ -2,157 +2,32 @@ require 'spec_helper' -RSpec.describe ::Packages::Npm::PackagePresenter do - using RSpec::Parameterized::TableSyntax - - let_it_be(:project) { create(:project) } - let_it_be(:package_name) { "@#{project.root_namespace.path}/test" } - let_it_be(:package1) { create(:npm_package, version: '2.0.4', project: project, name: package_name) } - let_it_be(:package2) { create(:npm_package, version: '2.0.6', project: project, name: package_name) } - let_it_be(:latest_package) { create(:npm_package, version: '2.0.11', project: project, name: package_name) } - - let(:packages) { project.packages.npm.with_name(package_name).last_of_each_version } - let(:presenter) { described_class.new(package_name, packages) } - - describe '#versions' do - let_it_be('package_json') do - { - 'name': package_name, - 'version': '2.0.4', - 'deprecated': 'warning!', - 'bin': './cli.js', - 'directories': ['lib'], - 'engines': { 'npm': '^7.5.6' }, - '_hasShrinkwrap': false, - 'dist': { - 'tarball': 'http://localhost/tarball.tgz', - 'shasum': '1234567890' - }, - 'custom_field': 'foo_bar' - } - end - - let(:presenter) { described_class.new(package_name, packages) } - - subject { presenter.versions } - - where(:has_dependencies, :has_metadatum) do - true | true - false | true - true | false - false | false - end - - with_them do - if params[:has_dependencies] - ::Packages::DependencyLink.dependency_types.keys.each do |dependency_type| - let_it_be("package_dependency_link_for_#{dependency_type}") { create(:packages_dependency_link, package: package1, dependency_type: dependency_type) } - end - end - - if params[:has_metadatum] - let_it_be('package_metadatadum') { create(:npm_metadatum, package: package1, package_json: package_json) } - end - - it { is_expected.to be_a(Hash) } - it { expect(subject[package1.version].with_indifferent_access).to match_schema('public_api/v4/packages/npm_package_version') } - it { expect(subject[package2.version].with_indifferent_access).to match_schema('public_api/v4/packages/npm_package_version') } - it { expect(subject[package1.version]['custom_field']).to be_blank } - - context 'dependencies' do - ::Packages::DependencyLink.dependency_types.keys.each do |dependency_type| - if params[:has_dependencies] - it { expect(subject.dig(package1.version, dependency_type.to_s)).to be_any } - else - it { expect(subject.dig(package1.version, dependency_type)).to be nil } - end - - it { expect(subject.dig(package2.version, dependency_type)).to be nil } - end - end - - context 'metadatum' do - ::Packages::Npm::PackagePresenter::PACKAGE_JSON_ALLOWED_FIELDS.each do |metadata_field| - if params[:has_metadatum] - it { expect(subject.dig(package1.version, metadata_field)).not_to be nil } - else - it { expect(subject.dig(package1.version, metadata_field)).to be nil } - end - - it { expect(subject.dig(package2.version, metadata_field)).to be nil } - end - end +RSpec.describe Packages::Npm::PackagePresenter, feature_category: :package_registry do + let_it_be(:metadata) do + { + name: 'foo', + versions: { '1.0.0' => { 'dist' => { 'tarball' => 'http://localhost/tarball.tgz' } } }, + dist_tags: { 'latest' => '1.0.0' } + } + end - it 'avoids N+1 database queries' do - check_n_plus_one(:versions) do - create_list(:npm_package, 5, project: project, name: package_name).each do |npm_package| - next unless has_dependencies + subject { described_class.new(metadata) } - ::Packages::DependencyLink.dependency_types.keys.each do |dependency_type| - create(:packages_dependency_link, package: npm_package, dependency_type: dependency_type) - end - end - end - end + describe '#name' do + it 'returns the name' do + expect(subject.name).to eq('foo') end + end - context 'with package files pending destruction' do - let_it_be(:package_file_pending_destruction) { create(:package_file, :pending_destruction, package: package2, file_sha1: 'pending_destruction_sha1') } - - let(:shasums) { subject.values.map { |v| v.dig(:dist, :shasum) } } - - it 'does not return them' do - expect(shasums).not_to include(package_file_pending_destruction.file_sha1) - end + describe '#versions' do + it 'returns the versions' do + expect(subject.versions).to eq({ '1.0.0' => { 'dist' => { 'tarball' => 'http://localhost/tarball.tgz' } } }) end end describe '#dist_tags' do - subject { presenter.dist_tags } - - context 'for packages without tags' do - it { is_expected.to be_a(Hash) } - it { expect(subject["latest"]).to eq(latest_package.version) } - - it 'avoids N+1 database queries' do - check_n_plus_one(:dist_tags) do - create_list(:npm_package, 5, project: project, name: package_name) - end - end - end - - context 'for packages with tags' do - let_it_be(:package_tag1) { create(:packages_tag, package: package1, name: 'release_a') } - let_it_be(:package_tag2) { create(:packages_tag, package: package1, name: 'test_release') } - let_it_be(:package_tag3) { create(:packages_tag, package: package2, name: 'release_b') } - let_it_be(:package_tag4) { create(:packages_tag, package: latest_package, name: 'release_c') } - let_it_be(:package_tag5) { create(:packages_tag, package: latest_package, name: 'latest') } - - it { is_expected.to be_a(Hash) } - it { expect(subject[package_tag1.name]).to eq(package1.version) } - it { expect(subject[package_tag2.name]).to eq(package1.version) } - it { expect(subject[package_tag3.name]).to eq(package2.version) } - it { expect(subject[package_tag4.name]).to eq(latest_package.version) } - it { expect(subject[package_tag5.name]).to eq(latest_package.version) } - - it 'avoids N+1 database queries' do - check_n_plus_one(:dist_tags) do - create_list(:npm_package, 5, project: project, name: package_name).each_with_index do |npm_package, index| - create(:packages_tag, package: npm_package, name: "tag_#{index}") - end - end - end + it 'returns the dist_tags' do + expect(subject.dist_tags).to eq({ 'latest' => '1.0.0' }) end end - - def check_n_plus_one(field) - pkgs = project.packages.npm.with_name(package_name).last_of_each_version.preload_files - control = ActiveRecord::QueryRecorder.new { described_class.new(package_name, pkgs).public_send(field) } - - yield - - pkgs = project.packages.npm.with_name(package_name).last_of_each_version.preload_files - - expect { described_class.new(package_name, pkgs).public_send(field) }.not_to exceed_query_limit(control) - end end |