Skip to content

Commit

Permalink
fix(ui-mode): do not loose run information after writing into testDir (
Browse files Browse the repository at this point in the history
…#30312)

Partially reverts #30008
that started to reset all test results upon listing tests, including the
test that did just run and triggered re-listing.

#30300.
  • Loading branch information
mxschmitt authored Apr 10, 2024
1 parent b2ded9f commit 15b4231
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 6 deletions.
35 changes: 30 additions & 5 deletions packages/playwright/src/isomorphic/teleReceiver.ts
Original file line number Diff line number Diff line change
Expand Up @@ -131,6 +131,7 @@ type TeleReporterReceiverOptions = {
};

export class TeleReporterReceiver {
public isListing = false;
private _rootSuite: TeleSuite;
private _options: TeleReporterReceiverOptions;
private _reporter: Partial<ReporterV2>;
Expand All @@ -144,11 +145,6 @@ export class TeleReporterReceiver {
this._reporter = reporter;
}

reset() {
this._rootSuite._entries = [];
this._tests.clear();
}

dispatch(message: JsonEvent): Promise<void> | void {
const { method, params } = message;
if (method === 'onConfigure') {
Expand Down Expand Up @@ -209,6 +205,35 @@ export class TeleReporterReceiver {
projectSuite._project = this._parseProject(project);
for (const suite of project.suites)
this._mergeSuiteInto(suite, projectSuite);

// Remove deleted tests when listing. Empty suites will be auto-filtered
// in the UI layer.
if (this.isListing) {
const testIds = new Set<string>();
const collectIds = (suite: JsonSuite) => {
suite.entries.forEach(entry => {
if ('testId' in entry)
testIds.add(entry.testId);
else
collectIds(entry);
});
};
project.suites.forEach(collectIds);

const filterTests = (suite: TeleSuite) => {
suite._entries = suite._entries.filter(entry => {
if (entry.type === 'test') {
if (testIds.has(entry.id))
return true;
this._tests.delete(entry.id);
return false;
}
filterTests(entry);
return true;
});
};
filterTests(projectSuite);
}
}

private _onBegin() {
Expand Down
3 changes: 2 additions & 1 deletion packages/trace-viewer/src/ui/teleSuiteUpdater.ts
Original file line number Diff line number Diff line change
Expand Up @@ -123,9 +123,10 @@ export class TeleSuiteUpdater {
}

processListReport(report: any[]) {
this._receiver.reset();
this._receiver.isListing = true;
for (const message of report)
this._receiver.dispatch(message);
this._receiver.isListing = false;
}

processTestReportEvent(message: any) {
Expand Down
30 changes: 30 additions & 0 deletions tests/playwright-test/ui-mode-test-update.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,36 @@ test('should pick new / deleted tests', async ({ runUITest, writeFiles, deleteFi
`);
});

test('should not loose run information after execution if test wrote into testDir', async ({ runUITest, writeFiles, deleteFile }) => {
test.info().annotations.push({ type: 'issue', description: 'https://github.com/microsoft/playwright/issues/30300' });
const { page } = await runUITest({
'a.test.ts': `
import fs from 'fs';
import path from 'path';
import { test, expect } from '@playwright/test';
test('passes', () => {
fs.writeFileSync(path.join(test.info().project.testDir, 'something.txt'), 'hi');
});
`,
});
await expect.poll(dumpTestTree(page)).toBe(`
▼ ◯ a.test.ts
◯ passes
`);
await page.getByTitle('passes').click();
await page.getByTitle('Run all').click();
await page.waitForTimeout(5_000);
await expect(page.getByText('Did not run')).toBeHidden();
const listItem = page.getByTestId('actions-tree').getByRole('listitem');
await expect(
listItem,
'action list'
).toHaveText([
/Before Hooks[\d.]+m?s/,
/After Hooks[\d.]+m?s/,
]);
});

test('should pick new / deleted nested tests', async ({ runUITest, writeFiles, deleteFile }) => {
const { page } = await runUITest(basicTestTree);
await expect.poll(dumpTestTree(page)).toContain(`
Expand Down

0 comments on commit 15b4231

Please sign in to comment.