If you just want to view the code for using Lighthouse with Puppeteer, see example-lh-auth.js.
See the integration test docs for an example of how to run Lighthouse in your Jest tests on pages in both an authenticated and non-authenticated session.
There are two pages on the site:
/
- the homepage/dashboard
The homepage shows the login form, but only to users that are not signed in.
The dashboard shows a secret to users that are logged in, but shows an error to users that are not.
The server responds with different HTML for each of these pages and session states.
(Optional) To run the server:
# be in root lighthouse directory
yarn # install global project deps
yarn build-report
cd docs/recipes/auth
yarn # install deps related to just this recipe
yarn start # start the server on http://localhost:10632
Now that the server is started, let's login with Puppeteer and then run Lighthouse:
node example-lh-auth.js
What does this do? Read on....
Puppeteer - a browser automation tool - can be used to programmatically setup a session.
- Launch a new browser.
- Navigate to the login page.
- Fill and submit the login form.
- Run Lighthouse using the same browser.
First, launch Chrome and create a new page:
const browser = await puppeteer.launch({
// Set to false if you want to see the script in action.
headless: 'new',
slowMo: 50,
});
const page = await browser.newPage();
Navigate to the login form:
await page.goto('http://localhost:10632');
Given a login form like this:
<form action="/login" method="post">
<label>
Email:
<input type="email" name="email">
</label>
<label>
Password:
<input type="password" name="password">
</label>
<input type="submit">
</form>
Direct Puppeteer to fill and submit it:
const emailInput = await page.$('input[type="email"]');
await emailInput.type('[email protected]');
const passwordInput = await page.$('input[type="password"]');
await passwordInput.type('password');
await Promise.all([
page.$eval('.login-form', form => form.submit()),
page.waitForNavigation(),
]);
At this point, the session that Puppeteer is managing is now logged in.
Now run Lighthouse, using the same page as before:
// The local server is running on port 10632.
const url = 'http://localhost:10632/dashboard';
// Direct Lighthouse to use the same page.
// Disable storage reset so login session is preserved.
const result = await lighthouse(url, {disableStorageReset: true}, undefined, page);
const lhr = result.lhr;
// Direct Puppeteer to close the browser - we're done with it.
await browser.close();
All of the above is done in the example script. To run:
# make sure server is running (see beginning of recipe) ...
node example-lh-auth.js # login via puppeteer and run lighthouse
NOTE: We strongly recommend your tests use the form-based login flow above instead. Only directly set the token like this as a last resort.
If you don't have user credentials to login but you do have direct access to a token for authentication, you can instead directly set a cookie.
await page.setCookie({
name: 'myAuthCookie',
value: '<auth token goes here>',
url: 'http://localhost:10632/dashboard',
});