chore: add npm run lint-tests (#10252)
This commit is contained in:
parent
4c93417e8a
commit
f38f611478
|
|
@ -25,9 +25,10 @@
|
||||||
"tsc": "tsc -p .",
|
"tsc": "tsc -p .",
|
||||||
"build-installer": "babel -s --extensions \".ts\" --out-dir packages/playwright-core/lib/utils/ packages/playwright-core/src/utils",
|
"build-installer": "babel -s --extensions \".ts\" --out-dir packages/playwright-core/lib/utils/ packages/playwright-core/src/utils",
|
||||||
"doc": "node utils/doclint/cli.js",
|
"doc": "node utils/doclint/cli.js",
|
||||||
"lint": "npm run eslint && npm run tsc && npm run doc && npm run check-deps && node utils/generate_channels.js && node utils/generate_types/ --check-clean && npm run test-types && npm run lint-packages",
|
"lint": "npm run eslint && npm run tsc && npm run doc && npm run check-deps && node utils/generate_channels.js && node utils/generate_types/ --check-clean && npm run lint-tests && npm run test-types && npm run lint-packages",
|
||||||
"lint-packages": "node utils/prepare_packages.js --check-clean",
|
"lint-packages": "node utils/prepare_packages.js --check-clean",
|
||||||
"flint": "concurrently \"npm run eslint\" \"npm run tsc\" \"npm run doc\" \"npm run check-deps\" \"node utils/generate_channels.js\" \"node utils/generate_types/ --check-clean\" \"npm run test-types\" \"npm run lint-packages\"",
|
"lint-tests": "node utils/lint_tests.js",
|
||||||
|
"flint": "concurrently \"npm run eslint\" \"npm run tsc\" \"npm run doc\" \"npm run check-deps\" \"node utils/generate_channels.js\" \"node utils/generate_types/ --check-clean\" \"npm run lint-tests\" \"npm run test-types\" \"npm run lint-packages\"",
|
||||||
"clean": "rimraf packages/playwright-core/lib && rimraf packages/playwright-test/lib && rimraf packages/playwright-core/src/generated/",
|
"clean": "rimraf packages/playwright-core/lib && rimraf packages/playwright-test/lib && rimraf packages/playwright-core/src/generated/",
|
||||||
"prepare": "node install-from-github.js",
|
"prepare": "node install-from-github.js",
|
||||||
"build": "node utils/build/build.js",
|
"build": "node utils/build/build.js",
|
||||||
|
|
|
||||||
|
|
@ -94,8 +94,11 @@ export class Runner {
|
||||||
return prints;
|
return prints;
|
||||||
});
|
});
|
||||||
if (reporters.length && !someReporterPrintsToStdio) {
|
if (reporters.length && !someReporterPrintsToStdio) {
|
||||||
// Add a line/dot report for convenience.
|
// Add a line/dot/list-mode reporter for convenience.
|
||||||
// Important to put it first, jsut in case some other reporter stalls onEnd.
|
// Important to put it first, jsut in case some other reporter stalls onEnd.
|
||||||
|
if (list)
|
||||||
|
reporters.unshift(new ListModeReporter());
|
||||||
|
else
|
||||||
reporters.unshift(process.stdout.isTTY && !process.env.CI ? new LineReporter({ omitFailures: true }) : new DotReporter({ omitFailures: true }));
|
reporters.unshift(process.stdout.isTTY && !process.env.CI ? new LineReporter({ omitFailures: true }) : new DotReporter({ omitFailures: true }));
|
||||||
}
|
}
|
||||||
return new Multiplexer(reporters);
|
return new Multiplexer(reporters);
|
||||||
|
|
|
||||||
|
|
@ -42,7 +42,7 @@ test('should list tests', async ({ runInlineTest }) => {
|
||||||
].join('\n'));
|
].join('\n'));
|
||||||
});
|
});
|
||||||
|
|
||||||
test('should not list tests to stdout when JSON reporter is used', async ({ runInlineTest }) => {
|
test('should list tests to stdout when JSON reporter outputs to a file', async ({ runInlineTest }) => {
|
||||||
const result = await runInlineTest({
|
const result = await runInlineTest({
|
||||||
'playwright.config.ts': `
|
'playwright.config.ts': `
|
||||||
module.exports = { projects: [{ name: 'foo' }, {}] };
|
module.exports = { projects: [{ name: 'foo' }, {}] };
|
||||||
|
|
@ -58,7 +58,7 @@ test('should not list tests to stdout when JSON reporter is used', async ({ runI
|
||||||
`
|
`
|
||||||
}, { 'list': true, 'reporter': 'json' });
|
}, { 'list': true, 'reporter': 'json' });
|
||||||
expect(result.exitCode).toBe(0);
|
expect(result.exitCode).toBe(0);
|
||||||
expect(result.output).not.toContain('Listing tests');
|
expect(result.output).toContain('Listing tests');
|
||||||
expect(result.report.config.projects.length).toBe(2);
|
expect(result.report.config.projects.length).toBe(2);
|
||||||
expect(result.report.suites.length).toBe(1);
|
expect(result.report.suites.length).toBe(1);
|
||||||
expect(result.report.suites[0].specs.length).toBe(2);
|
expect(result.report.suites[0].specs.length).toBe(2);
|
||||||
|
|
|
||||||
33
utils/lint_tests.js
Normal file
33
utils/lint_tests.js
Normal file
|
|
@ -0,0 +1,33 @@
|
||||||
|
#!/usr/bin/env node
|
||||||
|
/**
|
||||||
|
* Copyright (c) Microsoft Corporation.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
const { execSync } = require('child_process');
|
||||||
|
const path = require('path');
|
||||||
|
|
||||||
|
// Note: we ignore stdout for smaller output.
|
||||||
|
try {
|
||||||
|
execSync('npm run test -- --list --forbid-only', {
|
||||||
|
stdio: ['ignore', 'ignore', 'inherit'],
|
||||||
|
cwd: path.join(__dirname, '..'),
|
||||||
|
});
|
||||||
|
execSync('npm run ttest -- --list --forbid-only', {
|
||||||
|
stdio: ['ignore', 'ignore', 'inherit'],
|
||||||
|
cwd: path.join(__dirname, '..'),
|
||||||
|
});
|
||||||
|
} catch (e) {
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
Loading…
Reference in a new issue