clawd/node_modules/puppeteer-core
Johan Jongsma 023030c035 Memory updates: corrections, email triage, heartbeat state
- Updated corrections.md with config validation principles
- Email triage rules and logs
- Infrastructure ownership documentation
- Daily memory files through Feb 1
- Heartbeat state tracking
2026-02-03 01:02:28 +00:00
..
lib Memory updates: corrections, email triage, heartbeat state 2026-02-03 01:02:28 +00:00
src Memory updates: corrections, email triage, heartbeat state 2026-02-03 01:02:28 +00:00
README.md Memory updates: corrections, email triage, heartbeat state 2026-02-03 01:02:28 +00:00
package.json Memory updates: corrections, email triage, heartbeat state 2026-02-03 01:02:28 +00:00

README.md

Puppeteer

build npm puppeteer package

Puppeteer is a JavaScript library which provides a high-level API to control Chrome or Firefox over the DevTools Protocol or WebDriver BiDi. Puppeteer runs in the headless (no visible UI) by default

Get started | API | FAQ | Contributing | Troubleshooting

Installation

npm i puppeteer # Downloads compatible Chrome during installation.
npm i puppeteer-core # Alternatively, install as a library, without downloading Chrome.

MCP

Install chrome-devtools-mcp, a Puppeteer-based MCP server for browser automation and debugging.

Example

import puppeteer from 'puppeteer';
// Or import puppeteer from 'puppeteer-core';

// Launch the browser and open a new blank page.
const browser = await puppeteer.launch();
const page = await browser.newPage();

// Navigate the page to a URL.
await page.goto('https://developer.chrome.com/');

// Set screen size.
await page.setViewport({width: 1080, height: 1024});

// Open the search menu using the keyboard.
await page.keyboard.press('/');

// Type into search box using accessible input name.
await page.locator('::-p-aria(Search)').fill('automate beyond recorder');

// Wait and click on first result.
await page.locator('.devsite-result-item-link').click();

// Locate the full title with a unique string.
const textSelector = await page
  .locator('::-p-text(Customize and automate)')
  .waitHandle();
const fullTitle = await textSelector?.evaluate(el => el.textContent);

// Print the full title.
console.log('The title of this blog post is "%s".', fullTitle);

await browser.close();