chore: use c8 coverage (#8495)

This commit is contained in:
jrandolf 2022-06-10 18:49:14 +02:00 committed by GitHub
parent 2b5a90dd72
commit 733cbecf48
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 3 additions and 59 deletions

View File

@ -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
View File

@ -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

View File

@ -1,6 +0,0 @@
const base = require('./base.js');
module.exports = {
...base,
spec: 'test/assert-coverage-test.js',
};

View File

@ -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",

View File

@ -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);
});
});

View File

@ -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 => {