2022-07-01 11:52:39 +00:00
# Puppeteer
2022-10-17 11:07:41 +00:00
[![Build status ](https://github.com/puppeteer/puppeteer/workflows/CI/badge.svg )](https://github.com/puppeteer/puppeteer/actions?query=workflow%3ACI)
[![npm puppeteer package ](https://img.shields.io/npm/v/puppeteer.svg )](https://npmjs.org/package/puppeteer)
2022-07-01 11:52:39 +00:00
< img src = "https://user-images.githubusercontent.com/10379601/29446482-04f7036a-841f-11e7-9872-91d1fc2ea683.png" height = "200" align = "right" / >
2022-10-28 06:49:28 +00:00
#### [Guides](https://pptr.dev/category/guides) | [API](https://pptr.dev/api) | [FAQ](https://pptr.dev/faq) | [Contributing](https://pptr.dev/contributing) | [Troubleshooting](https://pptr.dev/troubleshooting)
2022-07-01 11:52:39 +00:00
2022-10-17 11:07:41 +00:00
> Puppeteer is a Node.js library which provides a high-level API to control
> Chrome/Chromium over the
> [DevTools Protocol](https://chromedevtools.github.io/devtools-protocol/).
> Puppeteer runs in
> [headless](https://developers.google.com/web/updates/2017/04/headless-chrome)
> mode by default, but can be configured to run in full (non-headless)
> Chrome/Chromium.
2022-07-01 11:52:39 +00:00
2022-10-13 08:46:53 +00:00
#### What can I do?
2022-07-01 11:52:39 +00:00
2022-10-17 11:07:41 +00:00
Most things that you can do manually in the browser can be done using Puppeteer!
Here are a few examples to get you started:
2022-07-01 11:52:39 +00:00
- Generate screenshots and PDFs of pages.
2022-10-17 11:07:41 +00:00
- Crawl a SPA (Single-Page Application) and generate pre-rendered content (i.e.
"SSR" (Server-Side Rendering)).
2022-07-01 11:52:39 +00:00
- Automate form submission, UI testing, keyboard input, etc.
2022-10-17 11:07:41 +00:00
- Create an automated testing environment using the latest JavaScript and
browser features.
- Capture a
[timeline trace ](https://developers.google.com/web/tools/chrome-devtools/evaluate-performance/reference )
of your site to help diagnose performance issues.
2022-07-01 11:52:39 +00:00
- Test Chrome Extensions.
## Getting Started
### Installation
To use Puppeteer in your project, run:
```bash
npm i puppeteer
2022-10-13 08:46:53 +00:00
# or `yarn add puppeteer`
# or `pnpm i puppeteer`
2022-07-01 11:52:39 +00:00
```
2022-10-17 11:07:41 +00:00
When you install Puppeteer, it automatically downloads a recent version of
Chromium (~170MB macOS, ~282MB Linux, ~280MB Windows) that is
[guaranteed to work ](https://pptr.dev/faq#q-why-doesnt-puppeteer-vxxx-work-with-chromium-vyyy )
with Puppeteer. For a version of Puppeteer without installation, see
[`puppeteer-core` ](#puppeteer-core ).
2022-07-01 11:52:39 +00:00
2022-10-28 06:49:28 +00:00
#### Configuration
2022-10-24 07:07:05 +00:00
Puppeteer uses several defaults that can be customized through configuration
files.
For example, to change the default cache directory Puppeteer uses to install
browsers, you can add a `.puppeteerrc.cjs` (or `puppeteer.config.cjs` ) at the
root of your application with the contents
```js
const {join} = require('path');
/**
* @type {import("puppeteer").Configuration}
*/
module.exports = {
// Changes the cache location for Puppeteer.
cacheDirectory: join(__dirname, '.cache', 'puppeteer'),
};
```
After adding the configuration file, you will need to remove and reinstall
`puppeteer` for it to take effect.
2022-11-23 10:51:25 +00:00
See the [configuration guide ](https://pptr.dev/guides/configuration ) for more
2022-10-28 06:49:28 +00:00
information.
2022-07-01 11:52:39 +00:00
2022-10-13 08:46:53 +00:00
#### `puppeteer-core`
2022-07-01 11:52:39 +00:00
Every release since v1.7.0 we publish two packages:
- [`puppeteer` ](https://www.npmjs.com/package/puppeteer )
- [`puppeteer-core` ](https://www.npmjs.com/package/puppeteer-core )
2022-10-17 11:07:41 +00:00
`puppeteer` is a _product_ for browser automation. When installed, it downloads
a version of Chromium, which it then drives using `puppeteer-core` . Being an
2022-10-28 06:49:28 +00:00
end-user product, `puppeteer` automates several workflows using reasonable
defaults [that can be customized ](https://pptr.dev/guides/configuration ).
2022-07-01 11:52:39 +00:00
2022-10-17 11:07:41 +00:00
`puppeteer-core` is a _library_ to help drive anything that supports DevTools
2022-10-24 07:07:05 +00:00
protocol. Being a library, `puppeteer-core` is fully driven through its
programmatic interface implying no defaults are assumed and `puppeteer-core`
will not download Chromium when installed.
2022-10-28 06:49:28 +00:00
You should use `puppeteer-core` if you are
[connecting to a remote browser ](https://pptr.dev/api/puppeteer.puppeteer.connect )
or [managing browsers yourself ](https://pptr.dev/api/puppeteer.browserfetcher ).
If you are managing browsers yourself, you will need to call
2022-10-17 11:07:41 +00:00
[`puppeteer.launch` ](https://pptr.dev/api/puppeteer.puppeteernode.launch ) with
2022-10-24 07:07:05 +00:00
an an explicit
2022-10-17 11:07:41 +00:00
[`executablePath` ](https://pptr.dev/api/puppeteer.launchoptions.executablepath )
2022-10-28 06:49:28 +00:00
(or [`channel` ](https://pptr.dev/api/puppeteer.launchoptions.channel ) if it's
installed in a standard location).
2022-07-01 11:52:39 +00:00
2022-10-13 08:46:53 +00:00
When using `puppeteer-core` , remember to change the import:
2022-07-01 11:52:39 +00:00
```ts
2022-10-13 08:46:53 +00:00
import puppeteer from 'puppeteer-core';
2022-07-01 11:52:39 +00:00
```
### Usage
2022-10-17 11:07:41 +00:00
Puppeteer follows the latest
[maintenance LTS ](https://github.com/nodejs/Release#release-schedule ) version of
Node.
2022-07-01 11:52:39 +00:00
2022-10-17 11:07:41 +00:00
Puppeteer will be familiar to people using other browser testing frameworks. You
[launch ](https://pptr.dev/api/puppeteer.puppeteernode.launch )/[connect](https://pptr.dev/api/puppeteer.puppeteernode.connect)
a [browser ](https://pptr.dev/api/puppeteer.browser ),
[create ](https://pptr.dev/api/puppeteer.browser.newpage ) some
[pages ](https://pptr.dev/api/puppeteer.page ), and then manipulate them with
[Puppeteer's API ](https://pptr.dev/api ).
2022-07-01 11:52:39 +00:00
2022-10-28 06:49:28 +00:00
For more in-depth usage, check our [guides ](https://pptr.dev/category/guides )
and [examples ](https://github.com/puppeteer/puppeteer/tree/main/examples ).
2022-07-01 11:52:39 +00:00
2022-10-13 08:46:53 +00:00
#### Example
2022-07-01 11:52:39 +00:00
2023-01-17 15:04:48 +00:00
The following example searches [developer.chrome.com ](https://developer.chrome.com/ ) for blog posts with text "automate beyond recorder", click on the first result and print the full title of the blog post.
2022-07-01 11:52:39 +00:00
```ts
2022-10-13 08:46:53 +00:00
import puppeteer from 'puppeteer';
2022-07-01 11:52:39 +00:00
(async () => {
const browser = await puppeteer.launch();
const page = await browser.newPage();
2023-01-17 15:04:48 +00:00
await page.goto('https://developer.chrome.com/');
2022-07-01 11:52:39 +00:00
2023-01-17 15:04:48 +00:00
// Set screen size
await page.setViewport({width: 1080, height: 1024});
2022-07-01 11:52:39 +00:00
2023-01-17 15:04:48 +00:00
// Type into search box
await page.type('.search-box__input', 'automate beyond recorder');
2022-08-05 09:00:09 +00:00
2023-01-17 15:04:48 +00:00
// Wait and click on first result
const searchResultSelector = '.search-box__link';
await page.waitForSelector(searchResultSelector);
await page.click(searchResultSelector);
2022-08-05 09:00:09 +00:00
2023-01-17 15:04:48 +00:00
// Localte the full title with a unique string
const textSelector = await page.waitForSelector(
'text/Customize and automate'
);
const fullTitle = await textSelector.evaluate(el => el.textContent);
2022-07-01 11:52:39 +00:00
2023-01-17 15:04:48 +00:00
// Print the full title
console.log('The title of this blog post is "%s".', fullTitle);
2022-07-01 11:52:39 +00:00
await browser.close();
})();
```
2022-10-13 08:46:53 +00:00
### Default runtime settings
2022-07-01 11:52:39 +00:00
**1. Uses Headless mode**
2022-10-17 11:07:41 +00:00
Puppeteer launches Chromium in
[headless mode ](https://developers.google.com/web/updates/2017/04/headless-chrome ).
To launch a full version of Chromium, set the
[`headless` ](https://pptr.dev/api/puppeteer.browserlaunchargumentoptions.headless )
option when launching a browser:
2022-07-01 11:52:39 +00:00
```ts
const browser = await puppeteer.launch({headless: false}); // default is true
```
**2. Runs a bundled version of Chromium**
2022-10-17 11:07:41 +00:00
By default, Puppeteer downloads and uses a specific version of Chromium so its
API is guaranteed to work out of the box. To use Puppeteer with a different
version of Chrome or Chromium, pass in the executable's path when creating a
`Browser` instance:
2022-07-01 11:52:39 +00:00
```ts
const browser = await puppeteer.launch({executablePath: '/path/to/Chrome'});
```
2022-10-17 11:07:41 +00:00
You can also use Puppeteer with Firefox Nightly (experimental support). See
[`Puppeteer.launch` ](https://pptr.dev/api/puppeteer.puppeteernode.launch ) for
more information.
2022-07-01 11:52:39 +00:00
2022-10-17 11:07:41 +00:00
See
[`this article` ](https://www.howtogeek.com/202825/what%E2%80%99s-the-difference-between-chromium-and-chrome/ )
for a description of the differences between Chromium and Chrome.
[`This article` ](https://chromium.googlesource.com/chromium/src/+/refs/heads/main/docs/chromium_browser_vs_google_chrome.md )
describes some differences for Linux users.
2022-07-01 11:52:39 +00:00
**3. Creates a fresh user profile**
2022-10-17 11:07:41 +00:00
Puppeteer creates its own browser user profile which it **cleans up on every
run**.
2022-07-01 11:52:39 +00:00
2022-10-13 08:46:53 +00:00
#### Using Docker
2022-11-23 10:51:25 +00:00
See our [Docker guide ](https://pptr.dev/guides/docker ).
2022-10-13 08:46:53 +00:00
#### Using Chrome Extensions
2022-11-23 10:51:25 +00:00
See our [Chrome extensions guide ](https://pptr.dev/guides/chrome-extensions ).
2022-07-01 11:52:39 +00:00
## Resources
- [API Documentation ](https://pptr.dev/api )
2022-10-28 06:49:28 +00:00
- [Guides ](https://pptr.dev/category/guides )
2022-07-01 11:52:39 +00:00
- [Examples ](https://github.com/puppeteer/puppeteer/tree/main/examples )
- [Community list of Puppeteer resources ](https://github.com/transitive-bullshit/awesome-puppeteer )
## Contributing
2022-10-17 11:07:41 +00:00
Check out our [contributing guide ](https://pptr.dev/contributing ) to get an
overview of Puppeteer development.
2022-07-01 11:52:39 +00:00
## FAQ
2022-10-17 11:07:41 +00:00
Our [FAQ ](https://pptr.dev/faq ) has migrated to
[our site ](https://pptr.dev/faq ).