
Product
Introducing Socket Firewall Enterprise: Flexible, Configurable Protection for Modern Package Ecosystems
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.
@humanmade/bulk-lighthouse
Advanced tools
Run bulk lighthouse tests using Google PageSpeed Insights API
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.
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.
bulk-lighthouse .config/lighthouse.json
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.
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/"
]
}
}
pagespeed engine uses the Google pagespeed API and requires pages to be public. If authentication is enabled, one suggested workaround is to use searchParams 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.FAQs
Run bulk lighthouse tests using Google PageSpeed Insights API
The npm package @humanmade/bulk-lighthouse receives a total of 141 weekly downloads. As such, @humanmade/bulk-lighthouse popularity was classified as not popular.
We found that @humanmade/bulk-lighthouse demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 8 open source maintainers collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Product
Socket Firewall Enterprise is now available with flexible deployment, configurable policies, and expanded language support.

Security News
Open source dashboard CNAPulse tracks CVE Numbering Authorities’ publishing activity, highlighting trends and transparency across the CVE ecosystem.

Product
Detect malware, unsafe data flows, and license issues in GitHub Actions with Socket’s new workflow scanning support.