import {act, render, screen, userEvent, waitFor} from 'sentry-test/reactTestingLibrary'; import AssignedTo from 'sentry/components/group/assignedTo'; import GroupStore from 'sentry/stores/groupStore'; import MemberListStore from 'sentry/stores/memberListStore'; import ProjectsStore from 'sentry/stores/projectsStore'; import TeamStore from 'sentry/stores/teamStore'; describe('Group > AssignedTo', () => { let USER_1, USER_2; let TEAM_1; let PROJECT_1; let GROUP_1; let organization; const project = TestStubs.Project(); beforeEach(() => { organization = TestStubs.Organization(); USER_1 = TestStubs.User({ id: '1', name: 'Jane Bloggs', email: 'janebloggs@example.com', }); USER_2 = TestStubs.User({ id: '2', name: 'John Smith', email: 'johnsmith@example.com', }); TEAM_1 = TestStubs.Team({ id: '3', name: 'COOL TEAM', slug: 'cool-team', }); PROJECT_1 = TestStubs.Project({ teams: [TEAM_1], }); GROUP_1 = TestStubs.Group({ id: '1337', project: { id: PROJECT_1.id, slug: PROJECT_1.slug, }, }); TeamStore.loadInitialData([TEAM_1]); ProjectsStore.loadInitialData([PROJECT_1]); GroupStore.loadInitialData([GROUP_1]); jest.spyOn(GroupStore, 'get').mockImplementation(() => GROUP_1); MockApiClient.addMockResponse({ url: '/organizations/org-slug/users/', body: [], }); }); afterEach(() => { MockApiClient.clearMockResponses(); GroupStore.reset(); TeamStore.reset(); MemberListStore.state = []; MemberListStore.loaded = false; }); const openMenu = async () => { userEvent.click(await screen.findByTestId('assignee-selector'), undefined, { // Skip hover to prevent tooltip from rendering skipHover: true, }); }; it('renders unassigned', () => { render(, {organization}); expect(screen.getByText('No-one')).toBeInTheDocument(); }); it('can assign team', async () => { const assignMock = MockApiClient.addMockResponse({ method: 'PUT', url: `/issues/${GROUP_1.id}/`, body: { ...GROUP_1, assignedTo: {...TEAM_1, type: 'team'}, }, }); render(, {organization}); act(() => MemberListStore.loadInitialData([USER_1, USER_2])); await openMenu(); expect(screen.queryByTestId('loading-indicator')).not.toBeInTheDocument(); const team1slug = `#${TEAM_1.slug}`; userEvent.click(screen.getByText(team1slug)); await waitFor(() => expect(assignMock).toHaveBeenCalledWith( '/issues/1337/', expect.objectContaining({ data: {assignedTo: 'team:3', assignedBy: 'assignee_selector'}, }) ) ); expect(await screen.findByText(team1slug)).toBeInTheDocument(); // TEAM_1 initials expect(screen.getByTestId('assignee-selector')).toHaveTextContent('CT'); }); it('successfully clears assignment', async () => { const assignMock = MockApiClient.addMockResponse({ method: 'PUT', url: `/issues/${GROUP_1.id}/`, body: { ...GROUP_1, assignedTo: {...TEAM_1, type: 'team'}, }, }); render(, {organization}); act(() => MemberListStore.loadInitialData([USER_1, USER_2])); await openMenu(); // Assign first item in list, which is TEAM_1 userEvent.click(screen.getByText(`#${TEAM_1.slug}`)); await waitFor(() => expect(assignMock).toHaveBeenCalledWith( '/issues/1337/', expect.objectContaining({ data: {assignedTo: 'team:3', assignedBy: 'assignee_selector'}, }) ) ); await openMenu(); userEvent.click(screen.getByRole('button', {name: 'Clear Assignee'})); // api was called with empty string, clearing assignment await waitFor(() => expect(assignMock).toHaveBeenLastCalledWith( '/issues/1337/', expect.objectContaining({ data: {assignedTo: '', assignedBy: 'assignee_selector'}, }) ) ); }); });