# frozen_string_literal: true require 'spec_helper' RSpec.describe GroupProjectsFinder do include_context 'GroupProjectsFinder context' subject { finder.execute } describe 'with a group member current user' do before do group.add_maintainer(current_user) end context "only shared" do let(:options) { { only_shared: true } } it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1]) } end context "only owned" do let(:options) { { only_owned: true } } context 'with subgroups projects' do before do options[:include_subgroups] = true end it { is_expected.to match_array([private_project, public_project, subgroup_project, subgroup_private_project]) } end context 'without subgroups projects' do it { is_expected.to match_array([private_project, public_project]) } end end context "all" do context 'with subgroups projects' do before do options[:include_subgroups] = true end it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1, private_project, public_project, subgroup_project, subgroup_private_project]) } end context 'without subgroups projects' do it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1, private_project, public_project]) } end context "with min access level" do let!(:shared_project_4) { create(:project, :internal, path: '8') } before do shared_project_4.project_group_links.create!(group_access: Gitlab::Access::REPORTER, group: group) end let(:params) { { min_access_level: Gitlab::Access::MAINTAINER } } it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1, private_project, public_project]) } end end end describe 'without group member current_user' do before do shared_project_2.add_maintainer(current_user) current_user.reload end context "only shared" do let(:options) { { only_shared: true } } context "without external user" do it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1]) } end context "with external user" do before do current_user.update!(external: true) end it { is_expected.to match_array([shared_project_2, shared_project_1]) } end end context "only owned" do let(:options) { { only_owned: true } } context "without external user" do before do private_project.add_maintainer(current_user) subgroup_private_project.add_maintainer(current_user) end context 'with subgroups projects' do before do options[:include_subgroups] = true end it { is_expected.to match_array([private_project, public_project, subgroup_project, subgroup_private_project]) } end context 'without subgroups projects' do it { is_expected.to match_array([private_project, public_project]) } end end context "with external user" do before do current_user.update!(external: true) end context 'with subgroups projects' do before do options[:include_subgroups] = true end it { is_expected.to match_array([public_project, subgroup_project]) } end context 'without subgroups projects' do it { is_expected.to eq([public_project]) } end end end context "all" do context 'with subgroups projects' do before do options[:include_subgroups] = true end it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1, public_project, subgroup_project]) } end context 'without subgroups projects' do it { is_expected.to match_array([shared_project_3, shared_project_2, shared_project_1, public_project]) } end end end describe 'with an admin current user' do let(:current_user) { create(:admin) } context "only shared" do let(:options) { { only_shared: true } } it { is_expected.to eq([shared_project_3, shared_project_2, shared_project_1]) } end context "only owned" do let(:options) { { only_owned: true } } it { is_expected.to eq([private_project, public_project]) } end context "all" do it { is_expected.to eq([shared_project_3, shared_project_2, shared_project_1, private_project, public_project]) } end end describe "no user" do context "only shared" do let(:options) { { only_shared: true } } it { is_expected.to match_array([shared_project_3, shared_project_1]) } end context "only owned" do let(:options) { { only_owned: true } } context 'with subgroups projects' do before do options[:include_subgroups] = true end it { is_expected.to match_array([public_project, subgroup_project]) } end context 'without subgroups projects' do it { is_expected.to eq([public_project]) } end end end describe 'feature availability' do let!(:project_with_issues_disabled) { create(:project, :issues_disabled, :internal, path: '9') } let!(:project_with_merge_request_disabled) { create(:project, :merge_requests_disabled, :internal, path: '10') } before do project_with_issues_disabled.project_group_links.create!(group_access: Gitlab::Access::REPORTER, group: group) project_with_merge_request_disabled.project_group_links.create!(group_access: Gitlab::Access::REPORTER, group: group) end context 'without issues and merge request enabled' do it { is_expected.to match_array([public_project, shared_project_1, shared_project_3, project_with_issues_disabled, project_with_merge_request_disabled]) } end context 'with issues enabled' do let(:params) { { with_issues_enabled: true } } it { is_expected.to match_array([public_project, shared_project_1, shared_project_3, project_with_merge_request_disabled]) } end context 'with merge request enabled' do let(:params) { { with_merge_requests_enabled: true } } it { is_expected.to match_array([public_project, shared_project_1, shared_project_3, project_with_issues_disabled]) } end context 'with issues and merge request enabled' do let(:params) { { with_merge_requests_enabled: true, with_issues_enabled: true } } it { is_expected.to match_array([public_project, shared_project_1, shared_project_3]) } end end describe 'limiting' do context 'without limiting' do it 'returns all projects' do expect(subject.count).to eq(3) end end context 'with limiting' do let(:options) { { limit: 1 } } it 'returns only the number of projects specified by the limit' do expect(subject.count).to eq(1) end end end end