Files
sign/packages/app-tests/e2e/user/auth-flow.spec.ts

62 lines
2.0 KiB
TypeScript
Raw Normal View History

2023-10-03 09:53:47 +01:00
import { type Page, expect, test } from '@playwright/test';
2024-02-22 22:58:51 +11:00
import {
extractUserVerificationToken,
seedTestEmail,
2024-02-22 22:58:51 +11:00
seedUser,
} from '@documenso/prisma/seed/users';
2023-10-03 09:53:47 +01:00
test.use({ storageState: { cookies: [], origins: [] } });
test('[USER] can sign up with email and password', async ({ page }: { page: Page }) => {
2024-02-22 22:58:51 +11:00
const username = 'Test User';
const email = seedTestEmail();
2024-02-22 22:58:51 +11:00
const password = 'Password123#';
2023-10-03 09:53:47 +01:00
await page.goto('/signup');
await page.getByLabel('Name').fill(username);
await page.getByLabel('Email').fill(email);
await page.getByLabel('Password', { exact: true }).fill(password);
feat: add global settings for teams (#1391) ## Description This PR introduces global settings for teams. At the moment, it allows team admins to configure the following: * The default visibility of the documents uploaded to the team account * Whether to include the document owner (sender) details when sending emails to the recipients. ### Include Sender Details If the Sender Details setting is enabled, the emails sent by the team will include the sender's name: > "Example User" on behalf of "Example Team" has invited you to sign "document.pdf" Otherwise, the email will say: > "Example Team" has invited you to sign "document.pdf" ### Default Document Visibility This new option allows users to set the default visibility for the documents uploaded to the team account. It can have the following values: * Everyone * Manager and above * Admins only If the default document visibility isn't set, the document will be set to the role of the user who created the document: * If a user with the "User" role creates a document, the document's visibility is set to "Everyone". * Manager role -> "Manager and above" * Admin role -> "Admins only" Otherwise, if there is a default document visibility value, it uses that value. #### Gotcha To avoid issues, the `document owner` and the `recipient` can access the document irrespective of their role. For example: * If a team member with the role "Member" uploads a document and the default document visibility is "Admins", only the document owner and admins can access the document. * Similar to the other scenarios. * If an admin uploads a document and the default document visibility is "Admins", the recipient can access the document. * The admins have access to all the documents. * Managers have access to documents with the visibility set to "Everyone" and "Manager and above" * Members have access only to the documents with the visibility set to "Everyone". ## Testing Performed Tested it locally.
2024-11-08 13:50:49 +02:00
const canvas = page.locator('canvas').first();
2023-10-03 09:53:47 +01:00
const box = await canvas.boundingBox();
if (box) {
await page.mouse.move(box.x + 40, box.y + 40);
2023-10-03 09:53:47 +01:00
await page.mouse.down();
await page.mouse.move(box.x + box.width - 2, box.y + box.height - 2);
2023-10-03 09:53:47 +01:00
await page.mouse.up();
}
2024-02-29 15:19:38 +11:00
await page.getByRole('button', { name: 'Next', exact: true }).click();
await page.getByLabel('Public profile username').fill(Date.now().toString());
2024-02-29 14:26:37 +11:00
await page.getByRole('button', { name: 'Complete', exact: true }).click();
2024-02-22 22:58:51 +11:00
await page.waitForURL('/unverified-account');
const { token } = await extractUserVerificationToken(email);
await page.goto(`/verify-email/${token}`);
await expect(page.getByRole('heading')).toContainText('Email Confirmed!');
// We now automatically redirect to the home page
// await page.getByRole('link', { name: 'Go back home' }).click();
2024-02-22 22:58:51 +11:00
2023-10-03 09:53:47 +01:00
await page.waitForURL('/documents');
await expect(page).toHaveURL('/documents');
});
test('[USER] can sign in using email and password', async ({ page }: { page: Page }) => {
2024-02-22 22:58:51 +11:00
const user = await seedUser();
2023-10-03 09:53:47 +01:00
await page.goto('/signin');
2024-02-22 22:58:51 +11:00
await page.getByLabel('Email').fill(user.email);
await page.getByLabel('Password', { exact: true }).fill('password');
2023-10-03 09:53:47 +01:00
await page.getByRole('button', { name: 'Sign In' }).click();
await page.waitForURL('/documents');
await expect(page).toHaveURL('/documents');
});