mirror of
https://github.com/documenso/documenso.git
synced 2025-11-17 02:01:33 +10:00
feat: improve tests
This commit is contained in:
@ -1,11 +1,16 @@
|
||||
# [[E2E Tests]]
|
||||
E2E_TEST_USERNAME="Test"
|
||||
E2E_TEST_USER_EMAIL="mytestuser@mail.com"
|
||||
E2E_TEST_USER_PASSWORD="test_password"
|
||||
E2E_TEST_SIGNER_NAME="Test Signer"
|
||||
E2E_TEST_SIGNER_EMAIL="testsigner@mail.com"
|
||||
E2E_TEST_SIGNING_SUBJECT="Test subject"
|
||||
E2E_TEST_SIGNING_MESSAGE="Test message"
|
||||
# User for the "auth.setup.ts" file and the authenticated tests
|
||||
E2E_TEST_AUTHENTICATE_USERNAME="New user"
|
||||
E2E_TEST_AUTHENTICATE_USER_EMAIL="mytestnewuser@mail.com"
|
||||
E2E_TEST_AUTHENTICATE_USER_PASSWORD="new_test_password"
|
||||
# User for the *.unauthenticated.ts files
|
||||
E2E_TEST_USERNAME="Test"
|
||||
E2E_TEST_USER_EMAIL="mytestuser@mail.com"
|
||||
E2E_TEST_USER_PASSWORD="test_password"
|
||||
|
||||
# [[SMTP]]
|
||||
# OPTIONAL: Defines the transport to use for sending emails. Available options: smtp-auth (default) | smtp-api | mailchannels
|
||||
|
||||
@ -1,12 +1,13 @@
|
||||
import { deleteUser } from '@documenso/lib/server-only/user/delete-user';
|
||||
import { deleteUserAndItsData } from '@documenso/lib/server-only/user/delete-user-and-data';
|
||||
|
||||
async function teardown() {
|
||||
if (!process.env.E2E_TEST_USERNAME) {
|
||||
if (!process.env.E2E_TEST_USERNAME || !process.env.E2E_TEST_AUTHENTICATE_USERNAME) {
|
||||
return;
|
||||
}
|
||||
|
||||
try {
|
||||
await deleteUser(process.env.E2E_TEST_USERNAME);
|
||||
await deleteUserAndItsData(process.env.E2E_TEST_USERNAME);
|
||||
await deleteUserAndItsData(process.env.E2E_TEST_AUTHENTICATE_USERNAME);
|
||||
} catch (e) {
|
||||
throw new Error(`Error deleting user: ${e}`);
|
||||
}
|
||||
|
||||
@ -32,7 +32,7 @@ export default defineConfig({
|
||||
|
||||
/* Collect trace when retrying the failed test. See https://playwright.dev/docs/trace-viewer */
|
||||
trace: 'on-first-retry',
|
||||
video: 'retain-on-failure',
|
||||
navigationTimeout: 60 * 1000,
|
||||
},
|
||||
|
||||
/* Configure projects for major browsers */
|
||||
@ -41,7 +41,7 @@ export default defineConfig({
|
||||
{
|
||||
name: 'Authenticated User Tests',
|
||||
testMatch: '*.authenticated.spec.ts',
|
||||
dependencies: ['setup'],
|
||||
dependencies: ['setup', 'cleanup db'],
|
||||
use: {
|
||||
...devices['Desktop Chrome'],
|
||||
storageState: STORAGE_STATE,
|
||||
@ -49,6 +49,7 @@ export default defineConfig({
|
||||
},
|
||||
{
|
||||
name: 'Unauthenticated User Tests',
|
||||
dependencies: ['cleanup db'],
|
||||
use: {
|
||||
...devices['Desktop Chrome'],
|
||||
},
|
||||
|
||||
@ -2,9 +2,9 @@ import { type Page, expect, test as setup } from '@playwright/test';
|
||||
|
||||
import { STORAGE_STATE } from '../../../playwright.config';
|
||||
|
||||
const username = process.env.E2E_TEST_USERNAME || '';
|
||||
const email = process.env.E2E_TEST_USER_EMAIL || '';
|
||||
const password = process.env.E2E_TEST_USER_PASSWORD || '';
|
||||
const username = process.env.E2E_TEST_AUTHENTICATE_USERNAME || '';
|
||||
const email = process.env.E2E_TEST_AUTHENTICATE_USER_EMAIL || '';
|
||||
const password = process.env.E2E_TEST_AUTHENTICATE_USER_PASSWORD || '';
|
||||
|
||||
setup('authenticate', async ({ page }: { page: Page }) => {
|
||||
await page.goto('/signup');
|
||||
@ -16,9 +16,9 @@ setup('authenticate', async ({ page }: { page: Page }) => {
|
||||
const box = await canvas.boundingBox();
|
||||
|
||||
if (box) {
|
||||
await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2);
|
||||
await page.mouse.move(box.x + box.width / 8, box.y + box.height / 6);
|
||||
await page.mouse.down();
|
||||
await page.mouse.move(box.x + box.width / 4, box.y + box.height / 4);
|
||||
await page.mouse.move(box.x + box.width / 8, box.y + box.height / 6);
|
||||
await page.mouse.up();
|
||||
}
|
||||
|
||||
@ -28,7 +28,7 @@ setup('authenticate', async ({ page }: { page: Page }) => {
|
||||
await page.getByLabel('Email').fill(email);
|
||||
await page.getByLabel('Password').fill(password);
|
||||
await page.getByRole('button', { name: 'Sign In' }).click();
|
||||
await page.waitForURL('/documents');
|
||||
|
||||
await expect(page).toHaveURL('/documents');
|
||||
await page.context().storageState({ path: STORAGE_STATE });
|
||||
});
|
||||
|
||||
@ -29,6 +29,9 @@ test('user can sign up with email and password', async ({ page }: { page: Page }
|
||||
}
|
||||
|
||||
await page.getByRole('button', { name: 'Sign Up' }).click();
|
||||
await page.waitForURL('/documents');
|
||||
|
||||
await expect(page).toHaveURL('/documents');
|
||||
});
|
||||
|
||||
test('user can login with user and password', async ({ page }: { page: Page }) => {
|
||||
@ -37,5 +40,6 @@ test('user can login with user and password', async ({ page }: { page: Page }) =
|
||||
await page.getByLabel('Password').fill(password);
|
||||
await page.getByRole('button', { name: 'Sign In' }).click();
|
||||
|
||||
await page.waitForURL('/documents');
|
||||
await expect(page).toHaveURL('/documents');
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user