Puppeteer Testing Library
pptr-testing-library
is a lightweight adapter allowing
DOM Testing Library
to be used with puppeteer
.
- npm
- Yarn
npm install --save-dev puppeteer pptr-testing-library
yarn add --dev puppeteer pptr-testing-library
Usage
const puppeteer = require('puppeteer')
const {getDocument, queries, waitFor} = require('pptr-testing-library')
const {getByTestId, getByLabelText} = queries
const browser = await puppeteer.launch()
const page = await browser.newPage()
// Grab ElementHandle for document
const $document = await getDocument(page)
// Your favorite query methods are available
const $form = await getByTestId($document, 'my-form')
// returned elements are Puppeteer ElementHandles too!
const $email = await getByLabelText($form, 'Email')
// interact with puppeteer like usual
await $email.type('pptr@example.com')
// waiting works too!
await waitFor(() => getByText('Loading...'))
A little too un-puppeteer for you? You can attach all the DOM Testing Library
methods directly onto puppeteer's ElementHandle
instead!
const puppeteer = require('puppeteer')
require('pptr-testing-library/extend')
const browser = await puppeteer.launch()
const page = await browser.newPage()
// getDocument is added to prototype of Page
const $document = await page.getDocument()
// query methods are added directly to prototype of ElementHandle
const $form = await $document.getByTestId('my-form')
// destructuring works if you explicitly call getQueriesForElement
const {getByLabelText} = $form.getQueriesForElement()
// ...
const $email = await getByLabelText('Email')
API
Unique methods, not part of DOM Testing Library
.
getDocument(page: puppeteer.Page): ElementHandle
- get an ElementHandle for the document
Forwarded methods
DOM Testing Library
is injected into the page that puppeteer is controlling on
each query, so all results will be async. It's still recommended that you use
puppeteer's built-in methods for interaction rather than fireEvent
.
Known Limitations
waitForElement
method is not exposed. Puppeteer has its own set of wait utilities that somewhat conflict with the style used inDOM Testing Library
. See the issue on GitHub.fireEvent
method is not exposed, use puppeteer's built-ins instead.expect
assertion extensions are not available.