import {render, screen, userEvent, waitFor} from 'sentry-test/reactTestingLibrary';
import {addErrorMessage} from 'sentry/actionCreators/indicator';
import {trackAdhocEvent} from 'sentry/utils/analytics';
import OrganizationJoinRequest from 'sentry/views/organizationJoinRequest';
jest.mock('sentry/utils/analytics', () => ({
trackAdhocEvent: jest.fn(),
}));
jest.mock('sentry/actionCreators/indicator');
describe('OrganizationJoinRequest', function () {
const org = TestStubs.Organization({slug: 'test-org'});
const endpoint = `/organizations/${org.slug}/join-request/`;
beforeEach(function () {
trackAdhocEvent.mockClear();
MockApiClient.clearMockResponses();
});
it('renders', function () {
render();
expect(screen.getByRole('heading', {name: 'Request to Join'})).toBeInTheDocument();
expect(screen.getByRole('textbox', {name: 'Email Address'})).toBeInTheDocument();
expect(screen.getByRole('button', {name: 'Request to Join'})).toBeInTheDocument();
expect(trackAdhocEvent).toHaveBeenCalledWith({
eventKey: 'join_request.viewed',
org_slug: org.slug,
});
});
it('submits', async function () {
const postMock = MockApiClient.addMockResponse({
url: endpoint,
method: 'POST',
});
render();
await userEvent.type(
screen.getByRole('textbox', {name: 'Email Address'}),
'email@example.com{enter}'
);
expect(postMock).toHaveBeenCalled();
expect(
await screen.findByRole('heading', {name: 'Request Sent'})
).toBeInTheDocument();
expect(
screen.queryByRole('button', {name: 'Request to Join'})
).not.toBeInTheDocument();
});
it('errors', async function () {
const postMock = MockApiClient.addMockResponse({
url: endpoint,
method: 'POST',
statusCode: 400,
});
render();
await userEvent.type(
screen.getByRole('textbox', {name: 'Email Address'}),
'email@example.com{enter}'
);
await waitFor(() => {
expect(postMock).toHaveBeenCalled();
expect(addErrorMessage).toHaveBeenCalled();
});
expect(screen.getByRole('heading', {name: 'Request to Join'})).toBeInTheDocument();
});
it('cancels', async function () {
const spy = jest.spyOn(window.location, 'assign').mockImplementation(() => {});
render();
await userEvent.click(screen.getByRole('button', {name: 'Cancel'}));
expect(spy).toHaveBeenCalledWith(`/auth/login/${org.slug}/`);
});
});