import {MemberFixture} from 'sentry-fixture/member'; import {OrganizationFixture} from 'sentry-fixture/organization'; import {TeamFixture} from 'sentry-fixture/team'; import {UserFixture} from 'sentry-fixture/user'; import { render, renderGlobalModal, screen, userEvent, } from 'sentry-test/reactTestingLibrary'; import selectEvent from 'sentry-test/selectEvent'; import TeamStore from 'sentry/stores/teamStore'; import type {OrgRole} from 'sentry/types/organization'; import InviteRequestRow from 'sentry/views/settings/organizationMembers/inviteRequestRow'; const roles: OrgRole[] = [ { id: 'admin', name: 'Admin', desc: 'This is the admin role', minimumTeamRole: '', isAllowed: true, }, { id: 'member', name: 'Member', desc: 'This is the member role', minimumTeamRole: '', isAllowed: true, }, { id: 'owner', name: 'Owner', desc: 'This is the owner role', minimumTeamRole: '', isAllowed: false, }, ]; describe('InviteRequestRow', function () { const orgWithoutAdminAccess = OrganizationFixture({ access: [], }); const orgWithAdminAccess = OrganizationFixture({ access: ['member:admin'], }); const inviteRequestBusy: Record = {}; const inviteRequest = MemberFixture({ user: null, inviterName: UserFixture().name, inviteStatus: 'requested_to_be_invited', role: 'member', teams: ['myteam'], }); const joinRequest = MemberFixture({ user: null, inviteStatus: 'requested_to_join', role: 'member', teams: ['myteam'], }); it('renders request to be invited', function () { render( {}} onDeny={() => {}} onUpdate={() => {}} allRoles={roles} /> ); expect(screen.getByText(inviteRequest.email)).toBeInTheDocument(); expect( screen.getByText(`Requested by ${inviteRequest.inviterName}`) ).toBeInTheDocument(); }); it('renders request to join', function () { render( {}} onDeny={() => {}} onUpdate={() => {}} allRoles={roles} /> ); expect(screen.getByText(joinRequest.email)).toBeInTheDocument(); expect(screen.getByRole('button', {name: 'Approve'})).toBeInTheDocument(); expect(screen.getByRole('button', {name: 'Deny'})).toBeInTheDocument(); }); it('admin can approve invite request', async function () { const mockApprove = jest.fn(); const mockDeny = jest.fn(); render( {}} allRoles={roles} /> ); await userEvent.click(screen.getByRole('button', {name: 'Approve'})); renderGlobalModal(); await userEvent.click(screen.getByTestId('confirm-button')); expect(mockApprove).toHaveBeenCalledWith(inviteRequest); expect(mockDeny).not.toHaveBeenCalled(); }); it('admin can deny invite request', async function () { const mockApprove = jest.fn(); const mockDeny = jest.fn(); render( {}} allRoles={roles} /> ); await userEvent.click(screen.getByRole('button', {name: 'Deny'})); expect(mockDeny).toHaveBeenCalledWith(inviteRequest); expect(mockApprove).not.toHaveBeenCalled(); }); it('non-admin can not approve or deny invite request', function () { render( {}} onDeny={() => {}} onUpdate={() => {}} allRoles={roles} /> ); expect(screen.getByRole('button', {name: 'Approve'})).toBeDisabled(); expect(screen.getByRole('button', {name: 'Deny'})).toBeDisabled(); }); it('admin can change role and teams', async function () { const adminInviteRequest = MemberFixture({ user: null, inviterName: UserFixture().name, inviteStatus: 'requested_to_be_invited', role: 'admin', teams: ['myteam'], }); void TeamStore.loadInitialData([ TeamFixture({id: '1', slug: 'one'}), TeamFixture({id: '2', slug: 'two'}), ]); const mockUpdate = jest.fn(); render( {}} onDeny={() => {}} onUpdate={mockUpdate} allRoles={roles} /> ); // Select role from first select input await selectEvent.select(screen.getAllByRole('textbox')[0], 'Member'); expect(mockUpdate).toHaveBeenCalledWith({role: 'member'}); // Select teams from first select input await selectEvent.select(screen.getAllByRole('textbox')[1], ['#one']); expect(mockUpdate).toHaveBeenCalledWith({teams: ['one']}); TeamStore.reset(); }); it('cannot be approved when invitee role is not allowed', function () { const ownerInviteRequest = MemberFixture({ user: null, inviterName: UserFixture().name, inviteStatus: 'requested_to_be_invited', role: 'owner', teams: ['myteam'], }); const mockUpdate = jest.fn(); render( {}} onDeny={() => {}} onUpdate={mockUpdate} allRoles={roles} /> ); expect(screen.getByRole('button', {name: 'Approve'})).toBeDisabled(); }); });