@humanmade/bulk-lighthouse
v2.0.3
Published
Run bulk lighthouse tests using Google PageSpeed Insights API
Downloads
373
Keywords
Readme
Bulk Lighthouse Tests.
Run bulk lighthouse tests using Google PageSpeed Insights API.
Define several URLs for significant pages on your site, and run tests against them all easily. The results are displayed in your console, and also saved in a file as JSON so that you can save for future reference.
Installation
From your project directory, run:
npm i @humanmade/bulk-lighthouse --save-dev
Create a config file for your project. See the 'Configuration' section of the docs for more details.
Running the script.
bulk-lighthouse .config/lighthouse.json
- Param 1. Path to config file.
- Param 2. (optional) Config group to run tests against.
It is recommended to add a script to your package.json
scripts. You can then execute the script with the following command npm run bulk-lighthouse
.
{
...
"scripts": {
"bulk-lighthouse": "bulk-lighthouse .config/lighthouse.json"
}
...
}
To run as a one-off, use npm run env -- bulk-lighthouse .config/lighthouse.json
.
Configuration.
Here is a basic config JSON file that you can copy/paste to get started.
{
"categories": {
"performance": {}
},
"strategies": [
"mobile",
"desktop"
],
"urls": {
"http://example.com"
}
}
googleApiKey
: Optional. See https://developers.google.com/speed/docs/insights/v5/get-started to generate an API key. Providing one will ensure that you don't hit rate limits. Only necessary when using the pagespeed
engine.
searchParams
Object. Optional. Add search params to the URL you're running the tests against. This can be used to pass keys for authentication.
categories
Required. Object. Pass at minimum, an empty object for each test to run. Optionally provide a pass/fail threshold for each test and strategy. By default, the thresholds are aligned with those used by Lighthouse tests for green and amber grades. The following config will performance, accessibility and SEO tests, with the addition of a custom pass threshold for performance test on mobile. See https://developers.google.com/speed/docs/insights/rest/v5/pagespeedapi/runpagespeed#Category.
"categories": {
"performance": {
"threshold": {
"desktop": 90,
"mobile": 70
}
},
"accessibility": {},
"seo": {},
},
strategies
Required. Array. The device running strategy to be used in analysis. Both, or one of desktop
or mobile
. See https://developers.google.com/speed/docs/insights/rest/v5/pagespeedapi/runpagespeed#strategy
engine
Optional (Defaults to pagespeed). String. Supported enginers are:
* pagespeed
(default) Tests are run using the pagespeed API. Faster, especially for large numbers of pages as they are run in parallel. But the limitation of this is that it can only be run against publicly accessible pages. See https://developers.google.com/speed/docs/insights/rest/v5/pagespeedapi/runpagespeed
* lighthouse
Uses lighthouse installed locally. Slower, and probably more chance of variance in results. But can be run against a site running locally.
urls
. Optional. Specify the group of URLs to run when executing the script e.g. node .scripts/lighthouse.js
.
"urls": [
"https://example.com/",
"https://example.com/about",
],
}
resultsDir
Optional. Directory in which to save results as JSON. Defaults to lighthouse-reports
.
batchSize
Optional. The number of URLs to include in each batch. Note this is only applicable when using the pagespeed engine. Defaults to 25
.
groups
Optional. Object. Group tests, e.g. by environment. Each groups allows you to pass a full config object that confirms to the same spec as the main configuration. This is merged with the top level config, with the group taking precedence.
{
...
"engine": "pagespeed",
"urls": [
"https://example.com",
"https://example.com/blog/test/"
]
"groups": {
"local": {
"engine": "lighthouse",
"urls": [
"https://example.local",
"https://example.local/blog/test/"
]
},
"staging": {
"searchParams": {
"key": "123456789"
}
"urls": [
"https://staging.example.com",
"https://staging.example.com/blog/test/"
]
}
}
}
In this example, the config file configures the bulk lighthouse tool to be run against production, using the pagespeed engine. Run the command without specifying a group e.g. bulk-lighthouse .config/lighthouse.json
.
The groups option is then used to modify the config for different environments. E.g. to run against local URLs, using the lighthouse`` engine, run
bulk-lighthouse .config/lighthouse.json local. Other options are inherited (e.g. categories, strategies) but could be overwritten if required e.g. pass the search param
key` only when running tests against the staging site.
## Upgrading from version 1.* to 2.*
Version 2.0 introduced some changes to the format of the config file.
In version 1.0, URLs could be an object, with each group as a key that contains an array of URLs. But in version 2.0 urls should be an array of URLs only.
```json
"urls": {
"production": [
"https://example.com/",
"https://example.com/about",
],
"staging": [
"https://staging.example.com/",
"https://staging.example.com/about",
]
}
If you wish to use groups functionaltiy, you should specify groups in the following format. For each group you can specify configuration that is merged with the top level config, allowing you more flexibility.
"groups": {
"local": {
"urls": [
"https://example.local",
"https://example.local/blog/test/"
]
},
"staging": {
"urls": [
"https://staging.example.com",
"https://staging.example.com/blog/test/"
]
}
}
Caveats
- Node v18 is required to run this project.
- The
pagespeed
engine uses the Google pagespeed API and requires pages to be public. If authentication is enabled, one suggested workaround is to usesearchParams
to append an authentication token to the tested page URL that could be used to bypass this, however your application will need to handle this. - Page Caching. Often full pages are cached for a short period of time, and it can introduce significant variance in results depending on whether you hit a cached page or not. To avoid this, this library actually makes a pre-flight request in an attempt to prime the cache of any page being tested. The downside of this is that this tool will only test front end performance, and real world performance may well be different from this if cache hit rates are low.
- Note that lighthouse test results can vary. They vary between runs, and the results you get from a single lighthouse test will vary from data provided by Chrome User Experience Reports.
- Basic auth. Unfortunately it is not supported to run tests against sites with basic authentication.