import {AccountEmailsFixture} from 'sentry-fixture/accountEmails';
import {render, screen, userEvent} from 'sentry-test/reactTestingLibrary';
import AccountEmails from 'sentry/views/settings/account/accountEmails';
jest.mock('scroll-to-element', () => {});
const ENDPOINT = '/users/me/emails/';
describe('AccountEmails', function () {
beforeEach(function () {
MockApiClient.clearMockResponses();
MockApiClient.addMockResponse({
url: ENDPOINT,
body: AccountEmailsFixture(),
});
});
it('renders with emails', function () {
render();
});
it('can remove an email', async function () {
const mock = MockApiClient.addMockResponse({
url: ENDPOINT,
method: 'DELETE',
statusCode: 200,
});
render();
expect(mock).not.toHaveBeenCalled();
await userEvent.click(
(await screen.findAllByRole('button', {name: 'Remove email'}))[0]
);
expect(mock).toHaveBeenCalledWith(
ENDPOINT,
expect.objectContaining({
method: 'DELETE',
data: {
email: 'secondary1@example.com',
},
})
);
});
it('can change a secondary email to primary an email', async function () {
const mock = MockApiClient.addMockResponse({
url: ENDPOINT,
method: 'PUT',
statusCode: 200,
});
render();
expect(mock).not.toHaveBeenCalled();
await userEvent.click(
(await screen.findAllByRole('button', {name: 'Set as primary'}))[0]
);
expect(mock).toHaveBeenCalledWith(
ENDPOINT,
expect.objectContaining({
method: 'PUT',
data: {
email: 'secondary1@example.com',
},
})
);
});
it('can resend verification email', async function () {
const mock = MockApiClient.addMockResponse({
url: `${ENDPOINT}confirm/`,
method: 'POST',
statusCode: 200,
});
render();
expect(mock).not.toHaveBeenCalled();
await userEvent.click(
(await screen.findAllByRole('button', {name: 'Resend verification'}))[0]
);
expect(mock).toHaveBeenCalledWith(
`${ENDPOINT}confirm/`,
expect.objectContaining({
method: 'POST',
data: {
email: 'secondary2@example.com',
},
})
);
});
it('can add a secondary email', async function () {
const mock = MockApiClient.addMockResponse({
url: ENDPOINT,
method: 'POST',
statusCode: 200,
});
render();
expect(mock).not.toHaveBeenCalled();
const mockGetResponseBody = [
...AccountEmailsFixture(),
{
email: 'test@example.com',
isPrimary: false,
isVerified: false,
},
];
const mockGet = MockApiClient.addMockResponse({
url: ENDPOINT,
method: 'GET',
statusCode: 200,
body: mockGetResponseBody,
});
const textbox = await screen.findByRole('textbox');
expect(screen.getAllByLabelText('Remove email')).toHaveLength(
AccountEmailsFixture().filter(email => !email.isPrimary).length
);
await userEvent.type(textbox, 'test@example.com{enter}');
expect(screen.getAllByLabelText('Remove email')).toHaveLength(
mockGetResponseBody.filter(email => !email.isPrimary).length
);
expect(mock).toHaveBeenCalledWith(
ENDPOINT,
expect.objectContaining({
method: 'POST',
data: {
email: 'test@example.com',
},
})
);
expect(mockGet).toHaveBeenCalledWith(
ENDPOINT,
expect.objectContaining({
method: 'GET',
})
);
});
});