chore: use c8 coverage (#8495)
This commit is contained in:
parent
2b5a90dd72
commit
733cbecf48
1
.github/workflows/ci.yml
vendored
1
.github/workflows/ci.yml
vendored
@ -76,7 +76,6 @@ jobs:
|
|||||||
CHROMIUM: true
|
CHROMIUM: true
|
||||||
run: |
|
run: |
|
||||||
xvfb-run --auto-servernum npm run test:unit:coverage
|
xvfb-run --auto-servernum npm run test:unit:coverage
|
||||||
xvfb-run --auto-servernum npm run test:coverage
|
|
||||||
|
|
||||||
- name: Run unit tests on Firefox
|
- name: Run unit tests on Firefox
|
||||||
uses: nick-invision/retry@v2
|
uses: nick-invision/retry@v2
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -21,5 +21,6 @@ new-docs/
|
|||||||
puppeteer*.tgz
|
puppeteer*.tgz
|
||||||
docs-api-json/
|
docs-api-json/
|
||||||
docs-dist/
|
docs-dist/
|
||||||
|
coverage
|
||||||
website/docs
|
website/docs
|
||||||
docs/api.html
|
docs/api.html
|
||||||
|
@ -1,6 +0,0 @@
|
|||||||
const base = require('./base.js');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
...base,
|
|
||||||
spec: 'test/assert-coverage-test.js',
|
|
||||||
};
|
|
@ -30,13 +30,12 @@
|
|||||||
"test": "npm run build && npm run lint --silent && npm run test:unit:coverage",
|
"test": "npm run build && npm run lint --silent && npm run test:unit:coverage",
|
||||||
"test:unit": "npm run build:tsc:cjs && npm run build:tsc:cjs:compat && mocha --config mocha-config/puppeteer-unit-tests.js",
|
"test:unit": "npm run build:tsc:cjs && npm run build:tsc:cjs:compat && mocha --config mocha-config/puppeteer-unit-tests.js",
|
||||||
"test:unit:firefox": "cross-env PUPPETEER_PRODUCT=firefox npm run test:unit",
|
"test:unit:firefox": "cross-env PUPPETEER_PRODUCT=firefox npm run test:unit",
|
||||||
"test:unit:coverage": "cross-env COVERAGE=1 npm run test:unit",
|
"test:unit:coverage": "c8 --check-coverage --lines 94 npm run test:unit",
|
||||||
"test:unit:chrome-headless": "cross-env HEADLESS=chrome npm run test:unit",
|
"test:unit:chrome-headless": "cross-env HEADLESS=chrome npm run test:unit",
|
||||||
"test:protocol-revision": "ts-node -s scripts/ensure-correct-devtools-protocol-package",
|
"test:protocol-revision": "ts-node -s scripts/ensure-correct-devtools-protocol-package",
|
||||||
"test:pinned-deps": "ts-node -s scripts/ensure-pinned-deps",
|
"test:pinned-deps": "ts-node -s scripts/ensure-pinned-deps",
|
||||||
"test:install": "scripts/test-install.sh",
|
"test:install": "scripts/test-install.sh",
|
||||||
"test:debug": "npm run build:tsc:cjs && npm run build:tsc:cjs:compat && mocha --inspect-brk --config mocha-config/puppeteer-unit-tests.js",
|
"test:debug": "npm run build:tsc:cjs && npm run build:tsc:cjs:compat && mocha --inspect-brk --config mocha-config/puppeteer-unit-tests.js",
|
||||||
"test:coverage": "cross-env COVERAGE=1 mocha --config mocha-config/coverage-tests.js",
|
|
||||||
"test:types": "ts-node -s scripts/test-ts-definition-files.ts",
|
"test:types": "ts-node -s scripts/test-ts-definition-files.ts",
|
||||||
"prepublishOnly": "npm run build",
|
"prepublishOnly": "npm run build",
|
||||||
"prepare": "node typescript-if-required.js && ([[ $HUSKY = 0 ]] || husky install)",
|
"prepare": "node typescript-if-required.js && ([[ $HUSKY = 0 ]] || husky install)",
|
||||||
@ -100,6 +99,7 @@
|
|||||||
"@types/ws": "8.5.3",
|
"@types/ws": "8.5.3",
|
||||||
"@typescript-eslint/eslint-plugin": "5.27.0",
|
"@typescript-eslint/eslint-plugin": "5.27.0",
|
||||||
"@typescript-eslint/parser": "5.27.0",
|
"@typescript-eslint/parser": "5.27.0",
|
||||||
|
"c8": "7.11.3",
|
||||||
"commonmark": "0.30.0",
|
"commonmark": "0.30.0",
|
||||||
"cross-env": "7.0.3",
|
"cross-env": "7.0.3",
|
||||||
"eslint": "8.16.0",
|
"eslint": "8.16.0",
|
||||||
|
@ -1,38 +0,0 @@
|
|||||||
const { describe, it } = require('mocha');
|
|
||||||
const { getCoverageResults } = require('./coverage-utils.js');
|
|
||||||
const expect = require('expect');
|
|
||||||
|
|
||||||
const EXCLUDED_METHODS = new Set([
|
|
||||||
'Puppeteer.registerCustomQueryHandler',
|
|
||||||
'Puppeteer.unregisterCustomQueryHandler',
|
|
||||||
'Puppeteer.customQueryHandlerNames',
|
|
||||||
'Puppeteer.clearCustomQueryHandlers',
|
|
||||||
'PuppeteerNode.connect',
|
|
||||||
'PuppeteerNode.launch',
|
|
||||||
'PuppeteerNode.executablePath',
|
|
||||||
'PuppeteerNode.defaultArgs',
|
|
||||||
'PuppeteerNode.createBrowserFetcher',
|
|
||||||
]);
|
|
||||||
|
|
||||||
describe('API coverage test', () => {
|
|
||||||
it('calls every method', () => {
|
|
||||||
if (!process.env.COVERAGE) return;
|
|
||||||
|
|
||||||
const coverageMap = getCoverageResults();
|
|
||||||
const missingMethods = [];
|
|
||||||
for (const method of coverageMap.keys()) {
|
|
||||||
if (!coverageMap.get(method) && !EXCLUDED_METHODS.has(method))
|
|
||||||
missingMethods.push(method);
|
|
||||||
}
|
|
||||||
if (missingMethods.length) {
|
|
||||||
console.error(
|
|
||||||
'\nCoverage check failed: not all API methods called. See above output for list of missing methods.'
|
|
||||||
);
|
|
||||||
console.error(missingMethods.join('\n'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// We know this will fail because we checked above
|
|
||||||
// but we need the actual test to fail.
|
|
||||||
expect(missingMethods.length).toEqual(0);
|
|
||||||
});
|
|
||||||
});
|
|
@ -30,7 +30,6 @@ import { Page } from '../lib/cjs/puppeteer/common/Page.js';
|
|||||||
import { PuppeteerNode } from '../lib/cjs/puppeteer/node/Puppeteer.js';
|
import { PuppeteerNode } from '../lib/cjs/puppeteer/node/Puppeteer.js';
|
||||||
import puppeteer from '../lib/cjs/puppeteer/puppeteer.js';
|
import puppeteer from '../lib/cjs/puppeteer/puppeteer.js';
|
||||||
import { TestServer } from '../utils/testserver/index.js';
|
import { TestServer } from '../utils/testserver/index.js';
|
||||||
import { trackCoverage } from './coverage-utils.js';
|
|
||||||
import utils from './utils.js';
|
import utils from './utils.js';
|
||||||
|
|
||||||
const setupServer = async () => {
|
const setupServer = async () => {
|
||||||
@ -225,15 +224,6 @@ export const describeChromeOnly = (
|
|||||||
if (isChrome) return describe(description, body);
|
if (isChrome) return describe(description, body);
|
||||||
};
|
};
|
||||||
|
|
||||||
let coverageHooks = {
|
|
||||||
beforeAll: (): void => {},
|
|
||||||
afterAll: (): void => {},
|
|
||||||
};
|
|
||||||
|
|
||||||
if (process.env['COVERAGE']) {
|
|
||||||
coverageHooks = trackCoverage();
|
|
||||||
}
|
|
||||||
|
|
||||||
console.log(
|
console.log(
|
||||||
`Running unit tests with:
|
`Running unit tests with:
|
||||||
-> product: ${product}
|
-> product: ${product}
|
||||||
@ -287,7 +277,6 @@ export const mochaHooks = {
|
|||||||
state.headless = headless;
|
state.headless = headless;
|
||||||
state.puppeteerPath = path.resolve(path.join(__dirname, '..'));
|
state.puppeteerPath = path.resolve(path.join(__dirname, '..'));
|
||||||
},
|
},
|
||||||
coverageHooks.beforeAll,
|
|
||||||
],
|
],
|
||||||
|
|
||||||
beforeEach: async (): Promise<void> => {
|
beforeEach: async (): Promise<void> => {
|
||||||
@ -302,7 +291,6 @@ export const mochaHooks = {
|
|||||||
await state.httpsServer.stop();
|
await state.httpsServer.stop();
|
||||||
state.httpsServer = null;
|
state.httpsServer = null;
|
||||||
},
|
},
|
||||||
coverageHooks.afterAll,
|
|
||||||
],
|
],
|
||||||
|
|
||||||
afterEach: (): void => {
|
afterEach: (): void => {
|
||||||
|
Loading…
Reference in New Issue
Block a user