2023-04-28 09:40:44 +03:00
|
|
|
import { ok } from 'node:assert';
|
2023-02-17 10:33:32 +03:00
|
|
|
import crypto from 'node:crypto';
|
2023-02-05 13:41:18 +03:00
|
|
|
import fs from 'node:fs';
|
2023-04-28 09:40:44 +03:00
|
|
|
import path, { resolve } from 'node:path';
|
2023-02-05 13:41:18 +03:00
|
|
|
import process from 'node:process';
|
2023-02-17 10:33:32 +03:00
|
|
|
|
2024-03-13 12:04:21 +03:00
|
|
|
import type { DocCollection } from '@blocksuite/store';
|
2024-03-25 06:55:32 +03:00
|
|
|
import type { BrowserContext } from '@playwright/test';
|
|
|
|
import { test as baseTest } from '@playwright/test';
|
2023-02-05 13:41:18 +03:00
|
|
|
|
2023-04-28 09:40:44 +03:00
|
|
|
export const rootDir = resolve(__dirname, '..', '..');
|
|
|
|
// assert that the rootDir is the root of the project
|
2023-06-29 07:13:35 +03:00
|
|
|
ok(
|
|
|
|
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
|
|
require(resolve(rootDir, 'package.json')).name.toLowerCase() ===
|
|
|
|
'@affine/monorepo'
|
|
|
|
);
|
2023-04-28 09:40:44 +03:00
|
|
|
|
|
|
|
export const testResultDir = resolve(rootDir, 'test-results');
|
|
|
|
|
2023-05-12 04:51:13 +03:00
|
|
|
export const istanbulTempDir = process.env.ISTANBUL_TEMP_DIR
|
2023-02-05 13:41:18 +03:00
|
|
|
? path.resolve(process.env.ISTANBUL_TEMP_DIR)
|
2023-05-12 04:51:13 +03:00
|
|
|
: path.join(rootDir, '.nyc_output');
|
2023-02-05 13:41:18 +03:00
|
|
|
|
|
|
|
function generateUUID() {
|
|
|
|
return crypto.randomUUID();
|
|
|
|
}
|
|
|
|
|
2023-05-12 04:51:13 +03:00
|
|
|
export const enableCoverage = !!process.env.CI || !!process.env.COVERAGE;
|
2023-02-05 13:41:18 +03:00
|
|
|
|
2024-03-13 12:04:21 +03:00
|
|
|
type CurrentDocCollection = {
|
2023-12-15 10:20:50 +03:00
|
|
|
meta: { id: string; flavour: string };
|
2024-03-13 12:04:21 +03:00
|
|
|
docCollection: DocCollection;
|
2023-07-13 15:41:46 +03:00
|
|
|
};
|
|
|
|
|
2023-12-19 10:17:54 +03:00
|
|
|
export const skipOnboarding = async (context: BrowserContext) => {
|
|
|
|
await context.addInitScript(() => {
|
2023-12-19 12:12:26 +03:00
|
|
|
window.localStorage.setItem(
|
|
|
|
'app_config',
|
|
|
|
'{"onBoarding":false, "dismissWorkspaceGuideModal":true}'
|
|
|
|
);
|
2023-12-19 10:17:54 +03:00
|
|
|
});
|
|
|
|
};
|
|
|
|
|
2023-07-13 15:41:46 +03:00
|
|
|
export const test = baseTest.extend<{
|
|
|
|
workspace: {
|
2024-03-13 12:04:21 +03:00
|
|
|
current: () => Promise<CurrentDocCollection>;
|
2023-07-13 15:41:46 +03:00
|
|
|
};
|
|
|
|
}>({
|
|
|
|
workspace: async ({ page }, use) => {
|
|
|
|
await use({
|
|
|
|
current: async () => {
|
|
|
|
return await page.evaluate(async () => {
|
2023-07-18 19:53:10 +03:00
|
|
|
if (!(globalThis as any).currentWorkspace) {
|
|
|
|
await new Promise<void>((resolve, reject) => {
|
|
|
|
globalThis.addEventListener(
|
|
|
|
'affine:workspace:change',
|
|
|
|
() => resolve(),
|
|
|
|
{
|
|
|
|
once: true,
|
|
|
|
}
|
|
|
|
);
|
2023-11-02 12:12:23 +03:00
|
|
|
setTimeout(() => reject(new Error('timeout')), 5000);
|
2023-07-18 19:53:10 +03:00
|
|
|
});
|
|
|
|
}
|
2023-07-13 15:41:46 +03:00
|
|
|
return (globalThis as any).currentWorkspace;
|
|
|
|
});
|
|
|
|
},
|
|
|
|
});
|
|
|
|
},
|
2024-02-06 06:20:48 +03:00
|
|
|
page: async ({ page, context }, use) => {
|
|
|
|
if (process.env.CPU_THROTTLE) {
|
|
|
|
const cdpSession = await context.newCDPSession(page);
|
|
|
|
await cdpSession.send('Emulation.setCPUThrottlingRate', {
|
|
|
|
rate: parseInt(process.env.CPU_THROTTLE),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
await use(page);
|
|
|
|
},
|
2023-02-05 13:41:18 +03:00
|
|
|
context: async ({ context }, use) => {
|
2023-12-19 10:17:54 +03:00
|
|
|
// workaround for skipping onboarding redirect on the web
|
|
|
|
await skipOnboarding(context);
|
|
|
|
|
2023-02-05 13:41:18 +03:00
|
|
|
if (enableCoverage) {
|
|
|
|
await context.addInitScript(() =>
|
|
|
|
window.addEventListener('beforeunload', () =>
|
|
|
|
// @ts-expect-error
|
|
|
|
window.collectIstanbulCoverage(JSON.stringify(window.__coverage__))
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
await fs.promises.mkdir(istanbulTempDir, { recursive: true });
|
|
|
|
await context.exposeFunction(
|
|
|
|
'collectIstanbulCoverage',
|
|
|
|
(coverageJSON?: string) => {
|
|
|
|
if (coverageJSON)
|
|
|
|
fs.writeFileSync(
|
|
|
|
path.join(
|
|
|
|
istanbulTempDir,
|
|
|
|
`playwright_coverage_${generateUUID()}.json`
|
|
|
|
),
|
|
|
|
coverageJSON
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
2023-04-15 01:07:41 +03:00
|
|
|
|
2023-02-05 13:41:18 +03:00
|
|
|
await use(context);
|
2023-04-15 01:07:41 +03:00
|
|
|
|
2023-02-05 13:41:18 +03:00
|
|
|
if (enableCoverage) {
|
|
|
|
for (const page of context.pages()) {
|
|
|
|
await page.evaluate(() =>
|
|
|
|
// @ts-expect-error
|
|
|
|
window.collectIstanbulCoverage(JSON.stringify(window.__coverage__))
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
});
|