Home Backend Development PHP Tutorial How to use PHP and Lighthouse for website performance testing

How to use PHP and Lighthouse for website performance testing

Jun 19, 2023 pm 03:36 PM
php Performance Testing lighthouse

As a web developer, you must know the importance of website performance to user experience and search engine rankings. To maintain a high-performance website, regular performance testing is required to detect and optimize website performance. Well, in this article, we will introduce how to use PHP and Lighthouse for website performance testing.

Lighthouse is an open source tool developed by Google for testing the quality and performance of web applications. It not only tests the speed of a web page, but also evaluates its accessibility, best practices, and search engine optimization. Generally speaking, we can use Lighthouse in Chrome browser, but if you need to integrate Lighthouse testing into your CI/CD pipeline or script, PHP is a good choice.

First of all, you need to make sure you have installed PHP and have some basic knowledge of PHP. Next, we need to install the Lighthouse PHP package. You can do it using the following command in the terminal:

composer require nunomaduro/laravel-mix-phplighthouse --dev
Copy after login

Here we use the nunomaduro/laravel-mix-phplighthouse package because it provides simple and easy-to-use commands to run Lighthouse tests and can easily Integrated with Laravel Mix. If you are not using Laravel Mix, consider using other PHP Lighthouse packages.

After the installation is complete, we need to set some configuration options of Lighthouse. Create a lighthouse.php file in the root directory of the project and add the following content:

<?php
return [
    'temp_dir' => 'storage/app/lighthouse',
    'chrome_path' => '/Applications/Google Chrome.app/Contents/MacOS/Google Chrome',
    'chrome_flags' => [
        '--show-paint-rects',
        '--headless',
    ],
    'audits' => [
        'first-contentful-paint',
        'largest-contentful-paint',
        'first-meaningful-paint',
        'speed-index',
        'total-blocking-time',
        'cumulative-layout-shift',
        'interactive',
        'uses-long-cache-ttl',
        'user-timings',
        'critical-request-chains',
        'redirects',
        'content-width',
        'font-display',
        'optimal-images',
    ],
];
Copy after login

In this configuration file, we define several options:

  • temp_dir: Specify Lighthouse The directory where test data is saved.
  • chrome_path: Specify the location of the Chrome browser.
  • chrome_flags: Specify some parameters of the Chrome browser, for example --headless means running in headless mode.
  • audits: Specify the audit items used in Lighthouse testing. Here we have selected some commonly used audit items, you can add or delete them according to your needs.

Next, create a file named test.php in the root directory of the project and add the following content:

<?php

require_once __DIR__.'/vendor/autoload.php';

use NunoMaduroPHPUnitLaravelTestCasesBrowserTestCase;

class LighthouseTest extends BrowserTestCase
{
    public function testPerformance()
    {
        $this->artisan('lighthouse https://www.example.com --json --no-interaction');
        $output = json_decode(file_get_contents(base_path('storage/app/lighthouse/report.json')), true);
        $this->assertArrayHasKey('audits', $output['categories']);
    }
}
Copy after login

In this file we created a file named LighthouseTest Test class, in this class, we define a test method called testPerformance. In this method, we use Artisan commands to run Lighthouse tests and save the results in JSON format to the specified directory. We then use the assertArrayHasKey method to check whether the Audits section is included in the test results.

Now you can run the test. Use the following command in the terminal to run the test:

./vendor/bin/phpunit --filter=LighthouseTest
Copy after login

This will run the testPerformance test method in the LighthouseTest test class we just created. If everything goes well, you will see that the test passed and a report.json file was generated in the storage/app/lighthouse directory, containing detailed information about the test results.

In addition to using the command line, we can also integrate Lighthouse testing into our PHP applications. Suppose we have a script named performancelog.php to record the performance of each page, then we can add the following code in this script to run the Lighthouse test:

require_once __DIR__.'/vendor/autoload.php';

use NunoMaduroPHPUnitLaravelTestCasesBrowserTestCase;

class LighthouseTest extends BrowserTestCase
{
    public function run()
    {
        $url = 'https://www.example.com';
        $this->artisan("lighthouse {$url} --json --no-interaction");
        $output = json_decode(file_get_contents(base_path('storage/app/lighthouse/report.json')), true);
        $categories = array_intersect_key($output['categories'], array_flip(['performance']));
        $score = array_sum(array_column($categories['performance']['auditRefs'], 'score')) / count($categories['performance']['auditRefs']);
        file_put_contents('performance.log', "{$url}: {$score}
", FILE_APPEND);
    }
}

$LighthouseTest = new LighthouseTest;
$LighthouseTest->run();
Copy after login

In this example, we use Lighthouse test The specified URL and log the score to the performance.log file. You can run this script periodically to monitor the performance of your web application.

In this article, we introduce how to use PHP and Lighthouse for website performance testing. Whether you are a web developer or a system administrator, you can use this tutorial to instrument and optimize the performance of your web applications.

The above is the detailed content of How to use PHP and Lighthouse for website performance testing. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
Two Point Museum: All Exhibits And Where To Find Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

CakePHP Project Configuration CakePHP Project Configuration Sep 10, 2024 pm 05:25 PM

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian PHP 8.4 Installation and Upgrade guide for Ubuntu and Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

CakePHP Date and Time CakePHP Date and Time Sep 10, 2024 pm 05:27 PM

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

CakePHP File upload CakePHP File upload Sep 10, 2024 pm 05:27 PM

To work on file upload we are going to use the form helper. Here, is an example for file upload.

CakePHP Routing CakePHP Routing Sep 10, 2024 pm 05:25 PM

In this chapter, we are going to learn the following topics related to routing ?

Discuss CakePHP Discuss CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

CakePHP Creating Validators CakePHP Creating Validators Sep 10, 2024 pm 05:26 PM

Validator can be created by adding the following two lines in the controller.

CakePHP Working with Database CakePHP Working with Database Sep 10, 2024 pm 05:25 PM

Working with database in CakePHP is very easy. We will understand the CRUD (Create, Read, Update, Delete) operations in this chapter.

See all articles