2023-04-08 00:55:59 +03:00
|
|
|
import type { PageMeta } from '@blocksuite/store';
|
2023-04-06 17:20:36 +03:00
|
|
|
import { faker } from '@faker-js/faker';
|
2023-03-17 10:51:00 +03:00
|
|
|
import type { Page } from '@playwright/test';
|
|
|
|
|
2023-03-30 01:49:13 +03:00
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
|
|
const user1 = require('@affine-test/fixtures/built-in-user1.json');
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
|
|
const user2 = require('@affine-test/fixtures/built-in-user2.json');
|
|
|
|
|
|
|
|
export async function getBuiltInUser() {
|
|
|
|
return Promise.all([
|
|
|
|
fetch('http://localhost:3000/api/user/token', {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
type: 'DebugLoginUser',
|
|
|
|
email: user1.email,
|
|
|
|
password: user1.password,
|
|
|
|
}),
|
|
|
|
}).then(r => r.json()),
|
|
|
|
fetch('http://localhost:3000/api/user/token', {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
type: 'DebugLoginUser',
|
|
|
|
email: user2.email,
|
|
|
|
password: user2.password,
|
|
|
|
}),
|
|
|
|
}).then(r => r.json()),
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
2023-04-06 17:20:36 +03:00
|
|
|
export async function createFakeUser(
|
|
|
|
userA = {
|
|
|
|
name: faker.name.fullName(),
|
|
|
|
email: faker.internet.email(),
|
|
|
|
password: faker.internet.password(),
|
|
|
|
},
|
|
|
|
userB = {
|
|
|
|
name: faker.name.fullName(),
|
|
|
|
email: faker.internet.email(),
|
|
|
|
password: faker.internet.password(),
|
|
|
|
}
|
|
|
|
) {
|
2023-03-17 10:51:00 +03:00
|
|
|
try {
|
|
|
|
const response = await Promise.all([
|
|
|
|
fetch('http://127.0.0.1:3000/api/user/token', {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
type: 'DebugLoginUser',
|
|
|
|
email: userA.email,
|
|
|
|
password: userA.password,
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
fetch('http://127.0.0.1:3000/api/user/token', {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
type: 'DebugLoginUser',
|
|
|
|
email: userB.email,
|
|
|
|
password: userB.password,
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
]);
|
|
|
|
return Promise.all(
|
|
|
|
response.map(res => {
|
|
|
|
if (!res.ok) {
|
|
|
|
throw new Error('User not found');
|
|
|
|
}
|
|
|
|
return res.json();
|
|
|
|
})
|
|
|
|
);
|
|
|
|
} catch (e) {
|
|
|
|
const response = await Promise.all([
|
|
|
|
// Register user A
|
|
|
|
fetch('http://localhost:3000/api/user/token', {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
type: 'DebugCreateUser',
|
|
|
|
...userA,
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
// Register user B
|
|
|
|
fetch('http://localhost:3000/api/user/token', {
|
|
|
|
method: 'POST',
|
|
|
|
headers: {
|
|
|
|
'Content-Type': 'application/json',
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
type: 'DebugCreateUser',
|
|
|
|
...userB,
|
|
|
|
}),
|
|
|
|
}),
|
|
|
|
]);
|
|
|
|
return Promise.all(response.map(res => res.json()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export async function loginUser(
|
|
|
|
page: Page,
|
|
|
|
token: {
|
|
|
|
refresh: string;
|
|
|
|
token: string;
|
|
|
|
}
|
|
|
|
) {
|
|
|
|
await page.evaluate(async token => {
|
2023-03-28 01:48:22 +03:00
|
|
|
globalThis.setLogin(token);
|
2023-03-17 10:51:00 +03:00
|
|
|
}, token);
|
|
|
|
}
|
|
|
|
|
2023-04-08 00:55:59 +03:00
|
|
|
export async function getMetas(page: Page): Promise<PageMeta[]> {
|
|
|
|
return page.evaluate(
|
|
|
|
() => globalThis.currentWorkspace.blockSuiteWorkspace.meta.pageMetas ?? []
|
|
|
|
);
|
|
|
|
}
|
2023-05-30 09:04:35 +03:00
|
|
|
|
|
|
|
export async function waitForLogMessage(
|
|
|
|
page: Page,
|
|
|
|
log: string
|
|
|
|
): Promise<boolean> {
|
|
|
|
return new Promise(resolve => {
|
|
|
|
page.on('console', msg => {
|
|
|
|
if (msg.type() === 'log' && msg.text() === log) {
|
|
|
|
resolve(true);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|