fix(test runner): do not validate fixtures in tests/hooks that are never run (#10328)

This commit is contained in:
Dmitry Gozman 2021-11-15 13:17:26 -08:00 committed by GitHub
parent fd3ec50cf6
commit 638ebd6dd6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 45 additions and 16 deletions

View File

@ -80,12 +80,6 @@ export class ProjectImpl {
}
private _cloneEntries(from: Suite, to: Suite, repeatEachIndex: number, filter: (test: TestCase) => boolean): boolean {
for (const hook of from._allHooks) {
const clone = hook._clone();
clone._pool = this.buildPool(hook);
clone._projectIndex = this.index;
to._addAllHook(clone);
}
for (const entry of from._entries) {
if (entry instanceof Suite) {
const suite = entry._clone();
@ -95,22 +89,31 @@ export class ProjectImpl {
to.suites.pop();
}
} else {
const pool = this.buildPool(entry);
const test = entry._clone();
test.retries = this.config.retries;
test._workerHash = `run${this.index}-${pool.digest}-repeat${repeatEachIndex}`;
test._id = `${entry._ordinalInFile}@${entry._requireFile}#run${this.index}-repeat${repeatEachIndex}`;
test._pool = pool;
test._repeatEachIndex = repeatEachIndex;
test._projectIndex = this.index;
to._addTest(test);
if (!filter(test)) {
to._entries.pop();
to.suites.pop();
to.tests.pop();
} else {
const pool = this.buildPool(entry);
test._workerHash = `run${this.index}-${pool.digest}-repeat${repeatEachIndex}`;
test._pool = pool;
}
}
}
return to._entries.length > 0;
if (!to._entries.length)
return false;
for (const hook of from._allHooks) {
const clone = hook._clone();
clone._pool = this.buildPool(hook);
clone._projectIndex = this.index;
to._addAllHook(clone);
}
return true;
}
cloneFileSuite(suite: Suite, repeatEachIndex: number, filter: (test: TestCase) => boolean): Suite | undefined {

View File

@ -27,7 +27,7 @@ import { Loader } from './loader';
import { Modifier, Suite, TestCase } from './test';
import { Annotations, TestError, TestInfo, TestInfoImpl, TestStepInternal, WorkerInfo } from './types';
import { ProjectImpl } from './project';
import { FixturePool, FixtureRunner } from './fixtures';
import { FixtureRunner } from './fixtures';
import { DeadlineRunner, raceAgainstDeadline } from 'playwright-core/lib/utils/async';
const removeFolderAsync = util.promisify(rimraf);
@ -148,15 +148,14 @@ export class WorkerRunner extends EventEmitter {
this._entries = new Map(runPayload.entries.map(e => [ e.testId, e ]));
await this._loadIfNeeded();
const fileSuite = await this._loader.loadTestFile(runPayload.file);
let anyPool: FixturePool | undefined;
const suite = this._project.cloneFileSuite(fileSuite, this._params.repeatEachIndex, test => {
if (!this._entries.has(test._id))
return false;
anyPool = test._pool;
return true;
});
if (suite && anyPool) {
this._fixtureRunner.setPool(anyPool);
if (suite) {
const firstPool = suite.allTests()[0]._pool!;
this._fixtureRunner.setPool(firstPool);
await this._runSuite(suite, []);
}
if (this._failedTest)

View File

@ -699,3 +699,30 @@ test('worker teardown errors reflected in timed-out tests', async ({ runInlineTe
expect(result.output).toContain('Timeout of 1000ms exceeded.');
expect(result.output).toContain('Rejecting!');
});
test('should not complain about fixtures of non-focused tests', async ({ runInlineTest }) => {
const result = await runInlineTest({
'a.test.js': `
const { test } = pwt;
test.only('works', () => {});
test('unknown fixture', ({ foo }) => {});
`,
});
expect(result.exitCode).toBe(0);
expect(result.passed).toBe(1);
});
test('should not complain about fixtures of unused hooks', async ({ runInlineTest }) => {
const result = await runInlineTest({
'a.test.js': `
const { test } = pwt;
test.only('works', () => {});
test.describe('unused suite', () => {
test.beforeAll(({ foo }) => {});
test('unused test', () => {});
});
`,
});
expect(result.exitCode).toBe(0);
expect(result.passed).toBe(1);
});