Files
gitlab-foss/spec/helpers/invite_members_helper_spec.rb
2025-07-04 06:07:47 +00:00

120 lines
3.9 KiB
Ruby

# 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_of: 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.md'),
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)).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))
.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).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_invite_project_members' do
before do
allow(helper).to receive(:can?).with(owner, :invite_project_members, 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, :invite_project_members, project)
end
end
context 'when the user can not manage project members' do
it 'returns false' do
expect(helper).to receive(:can?).with(owner, :invite_project_members, project).and_return(false)
expect(helper.can_invite_members_for_project?(project)).to eq false
end
end
end
end
describe '#invite_accepted_notice' do
context 'for group invites' do
let_it_be(:group) { create(:group, name: 'My group') }
let_it_be(:member) { build(:group_member, :guest, group: group) }
it 'returns the expected message' do
expect(helper.invite_accepted_notice(member))
.to eq('You have been granted access to the My group group with the following role: Guest.')
end
end
context 'for project invites' do
let_it_be(:project) { create(:project, name: 'My project') }
let_it_be(:member) { build(:project_member, :guest, project: project) }
it 'returns the expected message' do
expect(helper.invite_accepted_notice(member))
.to eq('You have been granted access to the My project project with the following role: Guest.')
end
end
end
end