import {fireEvent, render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
import {textWithMarkupMatcher} from 'sentry-test/utils';
import {openInviteMembersModal} from 'sentry/actionCreators/modal';
import {CommitRow} from 'sentry/components/commitRow';
import {Commit, Repository, RepositoryStatus, User} from 'sentry/types';
jest.mock('sentry/components/hovercard', () => {
return {
Header: ({children}: {children: React.ReactNode}) => children,
Body: ({children}: {children: React.ReactNode}) => children,
Hovercard: ({body}) => {
return body;
},
};
});
jest.mock('sentry/actionCreators/modal', () => {
return {
...jest.requireActual('sentry/actionCreators/modal'),
openInviteMembersModal: jest.fn(),
};
});
const baseCommit: Commit = {
dateCreated: '2020-11-30T18:46:31Z',
id: 'f7f395d14b2fe29a4e253bf1d3094d61e6ad4434',
message: 'ref(commitRow): refactor to fc\n',
author: {
id: '0',
username: 'author',
ip_address: '192.168.1.1',
email: 'author@commit.com',
name: 'Author',
} as User,
repository: {
id: '1',
integrationId: '2',
name: 'getsentry/sentry',
dateCreated: '2019-11-30T18:46:31Z',
} as Repository,
releases: [],
};
// static/app/components/hovercard.tsx
describe('commitRow', () => {
it('renders custom avatar', () => {
render();
expect(screen.getByText(/Custom Avatar/)).toBeInTheDocument();
});
it('renders invite flow for non associated users', () => {
const commit: Commit = {
...baseCommit,
author: {
...baseCommit.author,
id: undefined as unknown as string,
},
} as Commit;
render();
expect(
screen.getByText(
textWithMarkupMatcher(
/The email author@commit.com is not a member of your organization./
)
)
).toBeInTheDocument();
fireEvent.click(screen.getByText(/Invite/));
// @ts-ignore we are mocking this import
expect(openInviteMembersModal.mock.calls[0][0].initialData[0].emails).toEqual(
new Set(['author@commit.com'])
);
});
it('renders commit info', () => {
const commit: Commit = {
...baseCommit,
author: {
...baseCommit.author,
id: '0' as unknown as string,
},
} as Commit;
render();
expect(screen.getByText(/ref\(commitRow\): refactor to fc/)).toBeInTheDocument();
});
it('renders pull request', () => {
const commit: Commit = {
...baseCommit,
pullRequest: {
id: '9',
title: 'cool pr',
externalUrl: 'https://github.com/getsentry/sentry/pull/1',
repository: {
id: '14',
name: 'example',
url: '',
provider: {
id: 'unknown',
name: 'Unknown Provider',
},
status: RepositoryStatus.ACTIVE,
dateCreated: '2022-10-07T19:35:27.370422Z',
integrationId: '14',
externalSlug: 'org-slug',
},
},
};
const handlePullRequestClick = jest.fn();
render();
const pullRequestButton = screen.getByRole('button', {name: 'View Pull Request'});
expect(pullRequestButton).toBeInTheDocument();
expect(pullRequestButton).toHaveAttribute(
'href',
'https://github.com/getsentry/sentry/pull/1'
);
userEvent.click(pullRequestButton);
expect(handlePullRequestClick).toHaveBeenCalledTimes(1);
});
});