summaryrefslogtreecommitdiff
path: root/spec/finders/packages/group_packages_finder_spec.rb
diff options
context:
space:
mode:
Diffstat (limited to 'spec/finders/packages/group_packages_finder_spec.rb')
-rw-r--r--spec/finders/packages/group_packages_finder_spec.rb156
1 files changed, 156 insertions, 0 deletions
diff --git a/spec/finders/packages/group_packages_finder_spec.rb b/spec/finders/packages/group_packages_finder_spec.rb
new file mode 100644
index 00000000000..163c920f621
--- /dev/null
+++ b/spec/finders/packages/group_packages_finder_spec.rb
@@ -0,0 +1,156 @@
+# frozen_string_literal: true
+require 'spec_helper'
+
+RSpec.describe Packages::GroupPackagesFinder do
+ let_it_be(:user) { create(:user) }
+ let_it_be(:group) { create(:group) }
+ let_it_be(:project) { create(:project, namespace: group) }
+ let(:another_group) { create(:group) }
+
+ before do
+ group.add_developer(user)
+ end
+
+ describe '#execute' do
+ let(:params) { { exclude_subgroups: false } }
+
+ subject { described_class.new(user, group, params).execute }
+
+ shared_examples 'with package type' do |package_type|
+ let(:params) { { exclude_subgroups: false, package_type: package_type } }
+
+ it { is_expected.to match_array([send("package_#{package_type}")]) }
+ end
+
+ def self.package_types
+ @package_types ||= Packages::Package.package_types.keys
+ end
+
+ context 'group has packages' do
+ let!(:package1) { create(:maven_package, project: project) }
+ let!(:package2) { create(:maven_package, project: project) }
+ let!(:package3) { create(:maven_package) }
+
+ it { is_expected.to match_array([package1, package2]) }
+
+ context 'subgroup has packages' do
+ let(:subgroup) { create(:group, parent: group) }
+ let(:subproject) { create(:project, namespace: subgroup) }
+ let!(:package4) { create(:npm_package, project: subproject) }
+
+ it { is_expected.to match_array([package1, package2, package4]) }
+
+ context 'excluding subgroups' do
+ let(:params) { { exclude_subgroups: true } }
+
+ it { is_expected.to match_array([package1, package2]) }
+ end
+ end
+
+ context 'when there are processing packages' do
+ let!(:package4) { create(:nuget_package, project: project, name: Packages::Nuget::CreatePackageService::TEMPORARY_PACKAGE_NAME) }
+
+ it { is_expected.to match_array([package1, package2]) }
+ end
+
+ context 'does not include packages without version number' do
+ let!(:package_without_version) { create(:maven_package, project: project, version: nil) }
+
+ it { is_expected.not_to include(package_without_version) }
+ end
+
+ context 'with package_name' do
+ let_it_be(:named_package) { create(:maven_package, project: project, name: 'maven') }
+ let(:params) { { package_name: package_name } }
+
+ context 'as complete name' do
+ let(:package_name) { 'maven' }
+
+ it { is_expected.to eq([named_package]) }
+ end
+
+ %w[aven mav ave].each do |filter|
+ context "for fuzzy filter #{filter}" do
+ let(:package_name) { filter }
+
+ it { is_expected.to eq([named_package]) }
+ end
+ end
+ end
+ end
+
+ context 'group has package of all types' do
+ package_types.each { |pt| let!("package_#{pt}") { create("#{pt}_package", project: project) } }
+
+ package_types.each do |package_type|
+ it_behaves_like 'with package type', package_type
+ end
+ end
+
+ context 'group has no packages' do
+ it { is_expected.to be_empty }
+ end
+
+ context 'group is nil' do
+ subject { described_class.new(user, nil).execute }
+
+ it { is_expected.to be_empty}
+ end
+
+ context 'package type is nil' do
+ let!(:package1) { create(:maven_package, project: project) }
+
+ subject { described_class.new(user, group, package_type: nil).execute }
+
+ it { is_expected.to match_array([package1])}
+ end
+
+ context 'with invalid package_type' do
+ let(:params) { { package_type: 'invalid_type' } }
+
+ it { expect { subject }.to raise_exception(described_class::InvalidPackageTypeError) }
+ end
+
+ context 'when project is public' do
+ let_it_be(:other_user) { create(:user) }
+ let(:finder) { described_class.new(other_user, group) }
+
+ before do
+ project.update!(visibility_level: ProjectFeature::ENABLED)
+ end
+
+ context 'when packages are public' do
+ before do
+ project.project_feature.update!(
+ builds_access_level: ProjectFeature::PRIVATE,
+ merge_requests_access_level: ProjectFeature::PRIVATE,
+ repository_access_level: ProjectFeature::ENABLED)
+ end
+
+ it 'returns group packages' do
+ package1 = create(:maven_package, project: project)
+ package2 = create(:maven_package, project: project)
+ create(:maven_package)
+
+ expect(finder.execute).to match_array([package1, package2])
+ end
+ end
+
+ context 'packages are members only' do
+ before do
+ project.project_feature.update!(
+ builds_access_level: ProjectFeature::PRIVATE,
+ merge_requests_access_level: ProjectFeature::PRIVATE,
+ repository_access_level: ProjectFeature::PRIVATE)
+
+ create(:maven_package, project: project)
+ create(:maven_package)
+ end
+
+ it 'filters out the project if the user doesn\'t have permission' do
+ expect(finder.execute).to be_empty
+ end
+ end
+ end
+ end
+end