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,
|
2024-04-03 17:13:35 +08:00
|
|
|
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: [] } });
|
|
|
|
|
|
2024-04-03 17:13:35 +08:00
|
|
|
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';
|
2024-04-03 17:13:35 +08:00
|
|
|
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) {
|
2024-12-08 03:17:58 +00:00
|
|
|
await page.mouse.move(box.x + 40, box.y + 40);
|
2023-10-03 09:53:47 +01:00
|
|
|
await page.mouse.down();
|
2024-12-08 03:17:58 +00:00
|
|
|
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();
|
2024-04-03 15:18:36 +08:00
|
|
|
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!');
|
|
|
|
|
|
2024-08-28 14:08:35 +10:00
|
|
|
// 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');
|
|
|
|
|
});
|
|
|
|
|
|
2024-04-03 17:13:35 +08:00
|
|
|
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');
|
|
|
|
|
});
|