2023-05-09 10:30:01 +03:00
|
|
|
/* eslint-disable no-empty-pattern */
|
|
|
|
import crypto from 'node:crypto';
|
2023-05-12 04:51:13 +03:00
|
|
|
import { join, resolve } from 'node:path';
|
2023-05-09 10:30:01 +03:00
|
|
|
|
2023-05-12 04:51:13 +03:00
|
|
|
import {
|
|
|
|
enableCoverage,
|
|
|
|
istanbulTempDir,
|
|
|
|
test as base,
|
2023-05-15 09:13:30 +03:00
|
|
|
testResultDir,
|
2023-05-12 04:51:13 +03:00
|
|
|
} from '@affine-test/kit/playwright';
|
2023-05-09 10:30:01 +03:00
|
|
|
import fs from 'fs-extra';
|
|
|
|
import type { ElectronApplication, Page } from 'playwright';
|
|
|
|
import { _electron as electron } from 'playwright';
|
|
|
|
|
|
|
|
function generateUUID() {
|
|
|
|
return crypto.randomUUID();
|
|
|
|
}
|
|
|
|
|
2023-07-04 20:47:42 +03:00
|
|
|
type RoutePath = 'setting';
|
|
|
|
|
2023-05-09 10:30:01 +03:00
|
|
|
export const test = base.extend<{
|
|
|
|
page: Page;
|
|
|
|
electronApp: ElectronApplication;
|
|
|
|
appInfo: {
|
|
|
|
appPath: string;
|
|
|
|
appData: string;
|
|
|
|
sessionData: string;
|
|
|
|
};
|
2023-07-04 20:47:42 +03:00
|
|
|
router: {
|
|
|
|
goto: (path: RoutePath) => Promise<void>;
|
|
|
|
};
|
2023-05-09 10:30:01 +03:00
|
|
|
}>({
|
|
|
|
page: async ({ electronApp }, use) => {
|
|
|
|
const page = await electronApp.firstWindow();
|
|
|
|
await page.getByTestId('onboarding-modal-close-button').click({
|
|
|
|
delay: 100,
|
|
|
|
});
|
|
|
|
if (!process.env.CI) {
|
|
|
|
await electronApp.evaluate(({ BrowserWindow }) => {
|
|
|
|
BrowserWindow.getAllWindows()[0].webContents.openDevTools({
|
|
|
|
mode: 'detach',
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
2023-05-10 06:04:36 +03:00
|
|
|
// wat for blocksuite to be loaded
|
|
|
|
await page.waitForSelector('v-line');
|
2023-05-12 04:51:13 +03:00
|
|
|
if (enableCoverage) {
|
|
|
|
await fs.promises.mkdir(istanbulTempDir, { recursive: true });
|
|
|
|
await page.exposeFunction(
|
|
|
|
'collectIstanbulCoverage',
|
|
|
|
(coverageJSON?: string) => {
|
|
|
|
if (coverageJSON)
|
|
|
|
fs.writeFileSync(
|
|
|
|
join(
|
|
|
|
istanbulTempDir,
|
|
|
|
`playwright_coverage_${generateUUID()}.json`
|
|
|
|
),
|
|
|
|
coverageJSON
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
}
|
2023-05-09 10:30:01 +03:00
|
|
|
await use(page);
|
2023-05-12 04:51:13 +03:00
|
|
|
if (enableCoverage) {
|
|
|
|
await page.evaluate(() =>
|
|
|
|
// @ts-expect-error
|
|
|
|
window.collectIstanbulCoverage(JSON.stringify(window.__coverage__))
|
|
|
|
);
|
|
|
|
}
|
2023-05-09 10:30:01 +03:00
|
|
|
await page.close();
|
|
|
|
},
|
|
|
|
electronApp: async ({}, use) => {
|
|
|
|
// a random id to avoid conflicts between tests
|
|
|
|
const id = generateUUID();
|
2023-05-10 13:38:23 +03:00
|
|
|
const ext = process.platform === 'win32' ? '.cmd' : '';
|
2023-06-13 05:01:43 +03:00
|
|
|
const dist = resolve(__dirname, '..', 'dist');
|
|
|
|
const clonedDist = resolve(__dirname, '../e2e-dist-' + id);
|
|
|
|
await fs.copy(dist, clonedDist);
|
|
|
|
const packageJson = await fs.readJSON(
|
|
|
|
resolve(__dirname, '..', 'package.json')
|
|
|
|
);
|
|
|
|
// overwrite the app name
|
|
|
|
packageJson.name = 'affine-test-' + id;
|
|
|
|
// overwrite the path to the main script
|
|
|
|
packageJson.main = './main.js';
|
|
|
|
// write to the cloned dist
|
|
|
|
await fs.writeJSON(resolve(clonedDist, 'package.json'), packageJson);
|
|
|
|
|
2023-05-09 10:30:01 +03:00
|
|
|
const electronApp = await electron.launch({
|
2023-06-13 05:01:43 +03:00
|
|
|
args: [clonedDist],
|
2023-05-10 13:38:23 +03:00
|
|
|
executablePath: resolve(
|
|
|
|
__dirname,
|
|
|
|
'..',
|
|
|
|
'node_modules',
|
|
|
|
'.bin',
|
|
|
|
`electron${ext}`
|
|
|
|
),
|
2023-05-15 09:13:30 +03:00
|
|
|
recordVideo: {
|
|
|
|
dir: testResultDir,
|
|
|
|
},
|
2023-05-09 10:30:01 +03:00
|
|
|
colorScheme: 'light',
|
|
|
|
});
|
|
|
|
await use(electronApp);
|
2023-06-13 05:01:43 +03:00
|
|
|
try {
|
|
|
|
await fs.rm(clonedDist, { recursive: true, force: true });
|
|
|
|
} catch (error) {
|
|
|
|
console.log(error);
|
|
|
|
}
|
2023-05-09 10:30:01 +03:00
|
|
|
},
|
|
|
|
appInfo: async ({ electronApp }, use) => {
|
|
|
|
const appInfo = await electronApp.evaluate(async ({ app }) => {
|
|
|
|
return {
|
|
|
|
appPath: app.getAppPath(),
|
|
|
|
appData: app.getPath('appData'),
|
|
|
|
sessionData: app.getPath('sessionData'),
|
|
|
|
};
|
|
|
|
});
|
|
|
|
await use(appInfo);
|
|
|
|
},
|
|
|
|
});
|