# frozen_string_literal: true require "spec_helper" RSpec.describe InviteMembersHelper do include Devise::Test::ControllerHelpers let_it_be(:project) { create(:project) } let_it_be(:group) { create(:group, projects: [project]) } let_it_be(:developer) { create(:user, developer_projects: [project]) } let(:owner) { project.owner } describe '#common_invite_group_modal_data' do it 'has expected common attributes' do attributes = { id: project.id, root_id: project.root_ancestor.id, name: project.name, default_access_level: Gitlab::Access::GUEST, invalid_groups: project.related_group_ids, help_link: help_page_url('user/permissions'), is_project: 'true', access_levels: ProjectMember.access_level_roles.to_json, full_path: project.full_path } expect(helper.common_invite_group_modal_data(project, ProjectMember, 'true')).to include(attributes) end context 'when sharing with groups outside the hierarchy is disabled' do let_it_be(:group) { create(:group) } before do group.update!(prevent_sharing_groups_outside_hierarchy: true) end it 'provides the correct attributes' do expect(helper.common_invite_group_modal_data(group, GroupMember, 'false')) .to include({ groups_filter: 'descendant_groups', parent_id: group.id }) end end context 'when sharing with groups outside the hierarchy is enabled' do before do group.update!(prevent_sharing_groups_outside_hierarchy: false) end it 'does not return filter attributes' do expect(helper.common_invite_group_modal_data(project.group, ProjectMember, 'true').keys) .not_to include(:groups_filter, :parent_id) end end end describe '#common_invite_modal_dataset' do it 'has expected common attributes' do attributes = { id: project.id, root_id: project.root_ancestor.id, name: project.name, default_access_level: Gitlab::Access::GUEST, full_path: project.full_path } expect(helper.common_invite_modal_dataset(project)).to include(attributes) end end context 'with project' do before do allow(helper).to receive(:current_user) { owner } assign(:project, project) end describe "#can_invite_members_for_project?" do context 'when the user can_admin_project_member' do before do allow(helper).to receive(:can?).with(owner, :admin_project_member, project).and_return(true) end it 'returns true', :aggregate_failures do expect(helper.can_invite_members_for_project?(project)).to eq true expect(helper).to have_received(:can?).with(owner, :admin_project_member, project) end end context 'when the user can not manage project members' do it 'returns false' do expect(helper).to receive(:can?).with(owner, :admin_project_member, project).and_return(false) expect(helper.can_invite_members_for_project?(project)).to eq false end end end end end