mirror of
https://github.com/microsoft/playwright.git
synced 2025-06-26 21:40:17 +00:00
fix(electron): tracing with @playwright/test (#31437)
This commit is contained in:
parent
b349a73645
commit
9a3e0967e6
@ -609,7 +609,7 @@ class ArtifactsRecorder {
|
|||||||
if ((tracing as any)[this._startedCollectingArtifacts])
|
if ((tracing as any)[this._startedCollectingArtifacts])
|
||||||
return;
|
return;
|
||||||
(tracing as any)[this._startedCollectingArtifacts] = true;
|
(tracing as any)[this._startedCollectingArtifacts] = true;
|
||||||
if (this._testInfo._tracing.traceOptions())
|
if (this._testInfo._tracing.traceOptions() && (tracing as any)[kTracingStarted])
|
||||||
await tracing.stopChunk({ path: this._testInfo._tracing.generateNextTraceRecordingPath() });
|
await tracing.stopChunk({ path: this._testInfo._tracing.generateNextTraceRecordingPath() });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
*/
|
*/
|
||||||
import { test } from './npmTest';
|
import { test } from './npmTest';
|
||||||
import fs from 'fs';
|
import fs from 'fs';
|
||||||
|
import { expect } from 'packages/playwright-test';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
|
|
||||||
test('electron should work', async ({ exec, tsc, writeFiles }) => {
|
test('electron should work', async ({ exec, tsc, writeFiles }) => {
|
||||||
@ -39,3 +40,46 @@ test('electron should work with special characters in path', async ({ exec, tmpW
|
|||||||
cwd: path.join(folderName)
|
cwd: path.join(folderName)
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should work when wrapped inside @playwright/test and trace is enabled', async ({ exec, tmpWorkspace, writeFiles }) => {
|
||||||
|
await exec('npm i -D @playwright/test electron@31');
|
||||||
|
await writeFiles({
|
||||||
|
'electron-with-tracing.spec.ts': `
|
||||||
|
import { test, expect, _electron } from '@playwright/test';
|
||||||
|
|
||||||
|
test('should work', async ({ trace }) => {
|
||||||
|
const electronApp = await _electron.launch({ args: [${JSON.stringify(path.join(__dirname, '../electron/electron-window-app.js'))}] });
|
||||||
|
|
||||||
|
const window = await electronApp.firstWindow();
|
||||||
|
if (trace)
|
||||||
|
await window.context().tracing.start({ screenshots: true, snapshots: true });
|
||||||
|
|
||||||
|
await window.goto('data:text/html,<title>Playwright</title><h1>Playwright</h1>');
|
||||||
|
await expect(window).toHaveTitle(/Playwright/);
|
||||||
|
await expect(window.getByRole('heading')).toHaveText('Playwright');
|
||||||
|
|
||||||
|
const path = test.info().outputPath('electron-trace.zip');
|
||||||
|
if (trace) {
|
||||||
|
await window.context().tracing.stop({ path });
|
||||||
|
test.info().attachments.push({ name: 'trace', path, contentType: 'application/zip' });
|
||||||
|
}
|
||||||
|
await electronApp.close();
|
||||||
|
});
|
||||||
|
`,
|
||||||
|
});
|
||||||
|
const jsonOutputName = test.info().outputPath('report.json');
|
||||||
|
await exec('npx playwright test --trace=on --reporter=json electron-with-tracing.spec.ts', {
|
||||||
|
env: { PLAYWRIGHT_JSON_OUTPUT_NAME: jsonOutputName }
|
||||||
|
});
|
||||||
|
const traces = [
|
||||||
|
// our actual trace.
|
||||||
|
path.join(tmpWorkspace, 'test-results', 'electron-with-tracing-should-work', 'electron-trace.zip'),
|
||||||
|
// contains the expect() calls
|
||||||
|
path.join(tmpWorkspace, 'test-results', 'electron-with-tracing-should-work', 'trace.zip'),
|
||||||
|
];
|
||||||
|
for (const trace of traces)
|
||||||
|
expect(fs.existsSync(trace)).toBe(true);
|
||||||
|
const report = JSON.parse(fs.readFileSync(jsonOutputName, 'utf-8'));
|
||||||
|
expect(new Set(['trace'])).toEqual(new Set(report.suites[0].specs[0].tests[0].results[0].attachments.map(a => a.name)));
|
||||||
|
expect(new Set(traces.map(p => fs.realpathSync(p)))).toEqual(new Set(report.suites[0].specs[0].tests[0].results[0].attachments.map(a => a.path)));
|
||||||
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user