import {initializeOrg} from 'sentry-test/initializeOrg'; import {render, screen, userEvent, waitFor} from 'sentry-test/reactTestingLibrary'; import {openModal} from 'sentry/actionCreators/modal'; import ProjectOwnership from 'sentry/views/settings/project/projectOwnership'; jest.mock('sentry/actionCreators/modal'); describe('Project Ownership', () => { const {organization, project, routerProps} = initializeOrg(); beforeEach(() => { MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/ownership/`, method: 'GET', body: { fallthrough: false, autoAssignment: 'Auto Assign to Suspect Commits', codeownersAutoSync: false, }, }); MockApiClient.addMockResponse({ url: `/organizations/${organization.slug}/code-mappings/?project=${project.id}`, method: 'GET', body: [], }); MockApiClient.addMockResponse({ url: `/organizations/${organization.slug}/integrations/?features=codeowners`, method: 'GET', body: [TestStubs.GitHubIntegrationConfig()], }); MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/codeowners/`, method: 'GET', body: [], }); }); afterEach(() => { MockApiClient.clearMockResponses(); }); describe('without codeowners', () => { it('renders', () => { const wrapper = render( ); expect(wrapper.container).toSnapshot(); // Does not render codeowners for orgs without 'integrations-codeowners' feature expect( screen.queryByRole('button', {name: 'Add CODEOWNERS'}) ).not.toBeInTheDocument(); }); it('renders allows users to edit ownership rules', () => { render( , {organization: TestStubs.Organization({access: ['project:read']})} ); expect(screen.queryByRole('button', {name: 'Edit'})).toBeEnabled(); expect(screen.getByTestId('project-permission-alert')).toBeInTheDocument(); // eslint-disable-next-line jest-dom/prefer-in-document expect(screen.getAllByTestId('project-permission-alert')).toHaveLength(1); }); }); describe('with codeowners', () => { it('codeowners button opens modal', async () => { const org = TestStubs.Organization({ features: ['integrations-codeowners'], access: ['org:integrations'], }); render( , {context: TestStubs.routerContext([{organization: org}])} ); // Renders button expect(screen.getByRole('button', {name: 'Import CODEOWNERS'})).toBeInTheDocument(); // Opens modal await userEvent.click(screen.getByRole('button', {name: 'Import CODEOWNERS'})); expect(openModal).toHaveBeenCalled(); }); }); describe('issue owners settings', () => { it('should set autoAssignment with commit-context string', async () => { const updateOwnership = MockApiClient.addMockResponse({ url: `/projects/${organization.slug}/${project.slug}/ownership/`, method: 'PUT', body: { fallthrough: false, autoAssignment: 'Assign To Issue Owner', codeownersAutoSync: false, }, }); render( ); // Switch to Assign To Issue Owner await userEvent.click(screen.getByText('Auto-assign to suspect commits')); await userEvent.click(screen.getByText('Auto-assign to issue owner')); await waitFor(() => { expect(updateOwnership).toHaveBeenCalledWith( expect.anything(), expect.objectContaining({ data: { autoAssignment: 'Auto Assign to Issue Owner', }, }) ); }); }); it('should hide issue owners for issue-alert-fallback-targeting flag', () => { const org = { ...organization, features: ['issue-alert-fallback-targeting'], }; render( ); expect(screen.getByText('Prioritize Auto Assignment')).toBeInTheDocument(); expect( screen.queryByText('Send alert to project members if there’s no assigned owner') ).not.toBeInTheDocument(); }); }); });