Files
freeCodeCamp/e2e/report-user.spec.ts
Oliver Eyton-Williams 5b62ec7137 ci/e2e tests against mobile (#55347)
Co-authored-by: sembauke <semboot699@gmail.com>
2024-07-03 10:15:35 +05:30

55 lines
1.6 KiB
TypeScript

import { test, expect } from '@playwright/test';
import {
deleteAllEmails,
getAllEmails,
getFirstEmail,
getSubject
} from './utils/mailhog';
test.use({ storageState: 'playwright/.auth/certified-user.json' });
// To run this test you will need to run the email server.
// To do this: https://contribute.freecodecamp.org/#/how-to-catch-outgoing-emails-locally?id=using-mailhog
test.beforeEach(async () => {
await deleteAllEmails();
});
test('should be possible to report a user from their profile page', async ({
page,
isMobile
}) => {
await page.goto('/twaha');
// If you build the client locally, delete the button click below.
if (!process.env.CI) {
await page.getByRole('button', { name: 'Preview custom 404 page' }).click();
}
await page.getByText("Flag This User's Account for Abuse").click();
await expect(
page.getByText("Do you want to report twaha's portfolio for abuse?")
).toBeVisible();
// On mobile, the texarea is the first element due to the searchbox not being present
await page
.getByRole('textbox')
.nth(isMobile ? 0 : 1)
.fill('Some details');
await page.getByRole('button', { name: 'Submit the report' }).click();
await expect(page).toHaveURL('/learn');
await expect(page.getByTestId('flash-message')).toBeVisible();
await expect(page.getByTestId('flash-message')).toContainText(
'A report was sent to the team with foo@bar.com in copy'
);
await expect(async () => {
const emails = await getAllEmails();
expect(emails.items).toHaveLength(1);
expect(getSubject(getFirstEmail(emails))).toBe(
"Abuse Report : Reporting twaha's profile."
);
}).toPass();
});