mirror of
https://github.com/documenso/documenso.git
synced 2025-11-15 09:12:02 +10:00
## 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.
63 lines
2.0 KiB
TypeScript
63 lines
2.0 KiB
TypeScript
import { type Page, expect, test } from '@playwright/test';
|
|
|
|
import {
|
|
extractUserVerificationToken,
|
|
seedTestEmail,
|
|
seedUser,
|
|
} from '@documenso/prisma/seed/users';
|
|
|
|
test.use({ storageState: { cookies: [], origins: [] } });
|
|
|
|
test('[USER] can sign up with email and password', async ({ page }: { page: Page }) => {
|
|
const username = 'Test User';
|
|
const email = seedTestEmail();
|
|
const password = 'Password123#';
|
|
|
|
await page.goto('/signup');
|
|
await page.getByLabel('Name').fill(username);
|
|
await page.getByLabel('Email').fill(email);
|
|
await page.getByLabel('Password', { exact: true }).fill(password);
|
|
|
|
const canvas = page.locator('canvas').first();
|
|
const box = await canvas.boundingBox();
|
|
|
|
if (box) {
|
|
await page.mouse.move(box.x + box.width / 2, box.y + box.height / 2);
|
|
await page.mouse.down();
|
|
await page.mouse.move(box.x + box.width / 4, box.y + box.height / 4);
|
|
await page.mouse.up();
|
|
}
|
|
|
|
await page.getByRole('button', { name: 'Next', exact: true }).click();
|
|
await page.getByLabel('Public profile username').fill(Date.now().toString());
|
|
|
|
await page.getByRole('button', { name: 'Complete', exact: true }).click();
|
|
|
|
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();
|
|
|
|
await page.waitForURL('/documents');
|
|
|
|
await expect(page).toHaveURL('/documents');
|
|
});
|
|
|
|
test('[USER] can sign in using email and password', async ({ page }: { page: Page }) => {
|
|
const user = await seedUser();
|
|
|
|
await page.goto('/signin');
|
|
await page.getByLabel('Email').fill(user.email);
|
|
await page.getByLabel('Password', { exact: true }).fill('password');
|
|
await page.getByRole('button', { name: 'Sign In' }).click();
|
|
|
|
await page.waitForURL('/documents');
|
|
await expect(page).toHaveURL('/documents');
|
|
});
|