This package provide a php interface for Google Lighthouse.
You can install the package via composer: composer require dzava/lighthouse
Install Lighthouse yarn add lighthouse
. Last tested with Lighthouse v8.5.1.
Here's an example that will perform the default Lighthouse audits and store the result in report.json
(You can use the Lighthouse Viewer to open the report):
use Dzava\Lighthouse\Lighthouse;
(new Lighthouse())
->setOutput('report.json')
->accessibility()
->bestPractices()
->performance()
->pwa()
->seo()
->audit('http://example.com');
The setOutput
method accepts a second argument that can be used to specify the format (json,html).
If the format argument is missing then the file extension will be used to determine the output format.
If the file extension does not specify an accepted format, then json will be used.
You can output both the json and html reports by passing an array as the second argument. For the example
the following code will create two reports example.report.html
and example.report.json
.
use Dzava\Lighthouse\Lighthouse;
(new Lighthouse())
->setOutput('example', ['html', 'json'])
->performance()
->audit('http://example.com');
You can provide your own configuration file using the withConfig
method.
use Dzava\Lighthouse\Lighthouse;
(new Lighthouse())
->withConfig('./my-config.js')
->audit('http://example.com');
You can also pass a php array to the withConfig
method containing your configuration.
use Dzava\Lighthouse\Lighthouse;
(new Lighthouse())
->withConfig([
'extends' => 'lighthouse:default',
'settings' => [
'onlyCategories' => ['accessibility'],
],
])
->audit('http://example.com');
Note: in order to use an array to specify the configuration options, php needs to be able to create and move temporary files.
Details about the configuration options can be found here
If you need to manually set these paths, you can do this by calling the setNodeBinary
and setLighthousePath
methods.
use Dzava\Lighthouse\Lighthouse;
(new Lighthouse())
->setNodeBinary('/usr/bin/node')
->setLighthousePath('./node_modules/lighthouse/lighthouse-cli/index.js')
->audit('http://example.com');
Use the setChromeFlags
method to pass any flags to the Chrome instance.
use Dzava\Lighthouse\Lighthouse;
(new Lighthouse())
// these are the default flags used
->setChromeFlags(['--headless', '--disable-gpu', '--no-sandbox'])
->audit('http://example.com');
Use the following snippet to check why the audit fails.
require "./vendor/autoload.php";
use Dzava\Lighthouse\Exceptions\AuditFailedException;
use Dzava\Lighthouse\Lighthouse;
try {
(new Lighthouse())
->performance()
->audit('http://example.com');
} catch(AuditFailedException $e) {
echo $e->getOutput();
}