puppeteer/website/versioned_docs/version-22.6.2/api/puppeteer.coverage.md
release-please[bot] 3e1e419fe6
chore: release main (#12158)
Co-authored-by: release-please[bot] <55107282+release-please[bot]@users.noreply.github.com>
2024-03-28 14:36:37 +01:00

2.2 KiB

sidebar_label
Coverage

Coverage class

The Coverage class provides methods to gather information about parts of JavaScript and CSS that were used by the page.

Signature:

export declare class Coverage

Remarks

To output coverage in a form consumable by Istanbul, see puppeteer-to-istanbul.

Example

An example of using JavaScript and CSS coverage to get percentage of initially executed code:

// Enable both JavaScript and CSS coverage
await Promise.all([
  page.coverage.startJSCoverage(),
  page.coverage.startCSSCoverage(),
]);
// Navigate to page
await page.goto('https://example.com');
// Disable both JavaScript and CSS coverage
const [jsCoverage, cssCoverage] = await Promise.all([
  page.coverage.stopJSCoverage(),
  page.coverage.stopCSSCoverage(),
]);
let totalBytes = 0;
let usedBytes = 0;
const coverage = [...jsCoverage, ...cssCoverage];
for (const entry of coverage) {
  totalBytes += entry.text.length;
  for (const range of entry.ranges) usedBytes += range.end - range.start - 1;
}
console.log(`Bytes used: ${(usedBytes / totalBytes) * 100}%`);

Constructors

Constructor

Modifiers

Description

(constructor)(client)

Constructs a new instance of the Coverage class

Methods

Method

Modifiers

Description

startCSSCoverage(options)

startJSCoverage(options)

stopCSSCoverage()

Promise that resolves to the array of coverage reports for all stylesheets.

stopJSCoverage()

Promise that resolves to the array of coverage reports for all scripts.