mirror of
https://github.com/toeverything/AFFiNE.git
synced 2024-12-23 11:41:51 +03:00
3d3a66c3ed
This PR contains the following updates: | Package | Change | Age | Adoption | Passing | Confidence | |---|---|---|---|---|---| | [electron](https://redirect.github.com/electron/electron) | [`^32.0.0` -> `^33.0.0`](https://renovatebot.com/diffs/npm/electron/32.1.2/33.0.0) | [![age](https://developer.mend.io/api/mc/badges/age/npm/electron/33.0.0?slim=true)](https://docs.renovatebot.com/merge-confidence/) | [![adoption](https://developer.mend.io/api/mc/badges/adoption/npm/electron/33.0.0?slim=true)](https://docs.renovatebot.com/merge-confidence/) | [![passing](https://developer.mend.io/api/mc/badges/compatibility/npm/electron/32.1.2/33.0.0?slim=true)](https://docs.renovatebot.com/merge-confidence/) | [![confidence](https://developer.mend.io/api/mc/badges/confidence/npm/electron/32.1.2/33.0.0?slim=true)](https://docs.renovatebot.com/merge-confidence/) | --- ### Release Notes <details> <summary>electron/electron (electron)</summary> ### [`v33.0.0`](https://redirect.github.com/electron/electron/compare/v32.2.0...v33.0.0) [Compare Source](https://redirect.github.com/electron/electron/compare/v32.2.0...v33.0.0) ### [`v32.2.0`](https://redirect.github.com/electron/electron/releases/tag/v32.2.0): electron v32.2.0 [Compare Source](https://redirect.github.com/electron/electron/compare/v32.1.2...v32.2.0) ### Release Notes for v32.2.0 #### Fixes - Fixed a crash when calling `focus` on a `WebView`'s `webContents`. [#​43934](https://redirect.github.com/electron/electron/pull/43934) <span style="font-size:small;">(Also in [31](https://redirect.github.com/electron/electron/pull/43933), [33](https://redirect.github.com/electron/electron/pull/43932))</span> - Fixed a potential issue accessing a child window document when overriding browserWindow creation via `setWindowOpenHandler`. [#​43877](https://redirect.github.com/electron/electron/pull/43877) <span style="font-size:small;">(Also in [31](https://redirect.github.com/electron/electron/pull/43878), [33](https://redirect.github.com/electron/electron/pull/43816))</span> - Fixed an issue where an exception could be thrown on BrowserView after its owner BrowserWindow was closed. [#​44001](https://redirect.github.com/electron/electron/pull/44001) <span style="font-size:small;">(Also in [31](https://redirect.github.com/electron/electron/pull/43999), [33](https://redirect.github.com/electron/electron/pull/44000))</span> - Fixed closing a window with more than one attached sheet on macOS. [#​43954](https://redirect.github.com/electron/electron/pull/43954) <span style="font-size:small;">(Also in [31](https://redirect.github.com/electron/electron/pull/43953), [33](https://redirect.github.com/electron/electron/pull/43952))</span> - Fixed potential use-after-free during view removal on macOS. [#​43923](https://redirect.github.com/electron/electron/pull/43923) <span style="font-size:small;">(Also in [31](https://redirect.github.com/electron/electron/pull/43924), [33](https://redirect.github.com/electron/electron/pull/43922))</span> #### Other Changes - Ensured that the `sender-id` hint is set when creating desktop notifications on DBus. [#​43950](https://redirect.github.com/electron/electron/pull/43950) <span style="font-size:small;">(Also in [31](https://redirect.github.com/electron/electron/pull/43951), [33](https://redirect.github.com/electron/electron/pull/43949))</span> - Updated Chromium to 128.0.6613.178. [#​44086](https://redirect.github.com/electron/electron/pull/44086) - Updated Node.js to v20.18.0. [#​44116](https://redirect.github.com/electron/electron/pull/44116) </details> --- ### Configuration 📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR was generated by [Mend Renovate](https://mend.io/renovate/). View the [repository job log](https://developer.mend.io/github/toeverything/AFFiNE). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOC4xMjAuMSIsInVwZGF0ZWRJblZlciI6IjM4LjEyMC4xIiwidGFyZ2V0QnJhbmNoIjoiY2FuYXJ5IiwibGFiZWxzIjpbImRlcGVuZGVuY2llcyJdfQ==-->
229 lines
6.2 KiB
TypeScript
229 lines
6.2 KiB
TypeScript
import { openHomePage } from '@affine-test/kit/utils/load-page';
|
|
import {
|
|
clickNewPageButton,
|
|
waitForAllPagesLoad,
|
|
waitForEditorLoad,
|
|
} from '@affine-test/kit/utils/page-logic';
|
|
import {
|
|
clickSideBarCurrentWorkspaceBanner,
|
|
clickSideBarSettingButton,
|
|
} from '@affine-test/kit/utils/sidebar';
|
|
import { faker } from '@faker-js/faker';
|
|
import { hash } from '@node-rs/argon2';
|
|
import type { BrowserContext, Cookie, Page } from '@playwright/test';
|
|
import { expect } from '@playwright/test';
|
|
import type { Assertions } from 'ava';
|
|
import { z } from 'zod';
|
|
|
|
export async function getCurrentMailMessageCount() {
|
|
const response = await fetch('http://localhost:8025/api/v2/messages');
|
|
const data = await response.json();
|
|
return data.total;
|
|
}
|
|
|
|
export async function getLatestMailMessage() {
|
|
const response = await fetch('http://localhost:8025/api/v2/messages');
|
|
const data = await response.json();
|
|
return data.items[0];
|
|
}
|
|
|
|
export async function getTokenFromLatestMailMessage<A extends Assertions>(
|
|
test?: A
|
|
) {
|
|
const tokenRegex = /token=3D([^"&]+)/;
|
|
const emailContent = await getLatestMailMessage();
|
|
const tokenMatch = emailContent.Content.Body.match(tokenRegex);
|
|
const token = tokenMatch
|
|
? decodeURIComponent(tokenMatch[1].replace(/=\r\n/, ''))
|
|
: null;
|
|
test?.truthy(token);
|
|
return token;
|
|
}
|
|
|
|
export async function getLoginCookie(
|
|
context: BrowserContext
|
|
): Promise<Cookie | undefined> {
|
|
return (await context.cookies()).find(c => c.name === 'sid');
|
|
}
|
|
|
|
const cloudUserSchema = z.object({
|
|
id: z.string(),
|
|
name: z.string(),
|
|
email: z.string().email(),
|
|
password: z.string(),
|
|
});
|
|
|
|
export const runPrisma = async <T>(
|
|
cb: (
|
|
prisma: InstanceType<
|
|
// eslint-disable-next-line @typescript-eslint/consistent-type-imports
|
|
typeof import('../../../packages/backend/server/node_modules/@prisma/client').PrismaClient
|
|
>
|
|
) => Promise<T>
|
|
): Promise<T> => {
|
|
const {
|
|
PrismaClient,
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
} = require('../../../packages/backend/server/node_modules/@prisma/client');
|
|
const client = new PrismaClient();
|
|
await client.$connect();
|
|
try {
|
|
return await cb(client);
|
|
} finally {
|
|
await client.$disconnect();
|
|
}
|
|
};
|
|
|
|
export async function addUserToWorkspace(
|
|
workspaceId: string,
|
|
userId: string,
|
|
permission: number
|
|
) {
|
|
await runPrisma(async client => {
|
|
const workspace = await client.workspace.findUnique({
|
|
where: {
|
|
id: workspaceId,
|
|
},
|
|
});
|
|
if (workspace == null) {
|
|
throw new Error(`workspace ${workspaceId} not found`);
|
|
}
|
|
await client.workspaceUserPermission.create({
|
|
data: {
|
|
workspaceId: workspace.id,
|
|
userId,
|
|
accepted: true,
|
|
type: permission,
|
|
},
|
|
});
|
|
});
|
|
}
|
|
|
|
export async function createRandomUser(): Promise<{
|
|
name: string;
|
|
email: string;
|
|
password: string;
|
|
id: string;
|
|
}> {
|
|
const startTime = Date.now();
|
|
const user = {
|
|
name: faker.internet.userName(),
|
|
email: faker.internet.email().toLowerCase(),
|
|
password: '123456',
|
|
};
|
|
const result = await runPrisma(async client => {
|
|
const featureId = await client.feature
|
|
.findFirst({
|
|
where: { feature: 'free_plan_v1' },
|
|
select: { id: true },
|
|
orderBy: { version: 'desc' },
|
|
})
|
|
.then(f => f!.id);
|
|
|
|
await client.user.create({
|
|
data: {
|
|
...user,
|
|
emailVerifiedAt: new Date(),
|
|
password: await hash(user.password),
|
|
features: {
|
|
create: {
|
|
reason: 'created by test case',
|
|
activated: true,
|
|
featureId,
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
return await client.user.findUnique({
|
|
where: {
|
|
email: user.email,
|
|
},
|
|
});
|
|
});
|
|
const endTime = Date.now();
|
|
console.log(`createRandomUser takes: ${endTime - startTime}ms`);
|
|
cloudUserSchema.parse(result);
|
|
return {
|
|
...result,
|
|
password: user.password,
|
|
} as any;
|
|
}
|
|
|
|
export async function deleteUser(email: string) {
|
|
await runPrisma(async client => {
|
|
await client.user.delete({
|
|
where: {
|
|
email,
|
|
},
|
|
});
|
|
});
|
|
}
|
|
|
|
export async function loginUser(
|
|
page: Page,
|
|
user: {
|
|
email: string;
|
|
password: string;
|
|
},
|
|
config?: {
|
|
isElectron?: boolean;
|
|
beforeLogin?: () => Promise<void>;
|
|
afterLogin?: () => Promise<void>;
|
|
}
|
|
) {
|
|
if (config?.isElectron !== true) {
|
|
await openHomePage(page);
|
|
await waitForEditorLoad(page);
|
|
}
|
|
|
|
await clickSideBarCurrentWorkspaceBanner(page);
|
|
await page.getByTestId('cloud-signin-button').click();
|
|
await page.getByPlaceholder('Enter your email address').fill(user.email);
|
|
await page.getByTestId('continue-login-button').click({
|
|
delay: 200,
|
|
});
|
|
await page.getByTestId('password-input').fill(user.password);
|
|
if (config?.beforeLogin) {
|
|
await config.beforeLogin();
|
|
}
|
|
await page.waitForTimeout(200);
|
|
await page.getByTestId('sign-in-button').click();
|
|
await page.waitForTimeout(200);
|
|
if (config?.afterLogin) {
|
|
await config.afterLogin();
|
|
}
|
|
}
|
|
|
|
export async function enableCloudWorkspace(page: Page) {
|
|
await clickSideBarSettingButton(page);
|
|
await page.getByTestId('current-workspace-label').click();
|
|
await page.getByTestId('publish-enable-affine-cloud-button').click();
|
|
await page.getByTestId('confirm-enable-affine-cloud-button').click();
|
|
// wait for upload and delete local workspace
|
|
await page.waitForTimeout(2000);
|
|
await waitForAllPagesLoad(page);
|
|
await clickNewPageButton(page);
|
|
}
|
|
|
|
export async function enableCloudWorkspaceFromShareButton(page: Page) {
|
|
const shareMenuButton = page.getByTestId('local-share-menu-button');
|
|
await expect(shareMenuButton).toBeVisible();
|
|
|
|
await shareMenuButton.click();
|
|
await expect(page.getByTestId('local-share-menu')).toBeVisible();
|
|
|
|
await page.getByTestId('share-menu-enable-affine-cloud-button').click();
|
|
await page.getByTestId('confirm-enable-affine-cloud-button').click();
|
|
// wait for upload and delete local workspace
|
|
await page.waitForTimeout(2000);
|
|
await waitForEditorLoad(page);
|
|
await clickNewPageButton(page);
|
|
}
|
|
|
|
export async function enableShare(page: Page) {
|
|
await page.getByTestId('cloud-share-menu-button').click();
|
|
await page.getByTestId('share-link-menu-trigger').click();
|
|
await page.getByTestId('share-link-menu-enable-share').click();
|
|
}
|