Skip to main content

How to automate website performance regression testing

  In another post I went over how to analyze website performance using Lighthouse, and specifically how we can automate performance monitoring with Foo’s Automated Lighthouse Check. In this post I’m going to demonstrate how we can step it up a notch by regression testing performance… automagically 🔮.


What is Regression Testing?


Regression Testing is a type of software testing to confirm that a recent program or code change has not adversely affected existing features. Adhering to best practice could include the below.



Maintain a Strict Testing Schedule: Always maintain a continual testing schedule throughout the entire software development life cycle. Not only will this quickly force the team to adapt to a frequent testing regimen, it will also ensure the finished product is as well-tested as possible.


Use Test Management Software: Unless your current software project is a simple self-developed side project, chances are you’ll have such an abundance of tests that tracking each will be well beyond the capabilities of a single individual or a spreadsheet. Thankfully, there are many different test management tools on the market designed to simplify the process of creating, managing, tracking, and reporting on all the tests in your entire testing suite.


Categorize Your Tests: Imagine a test suite of hundreds or thousands of tests that are merely identified by a single name or id field. How on Earth would anyone ever sort through that massive list in order to identify tests that are related? The solution is to categorize tests into smaller groups based on whatever criteria is appropriate for your team. Most test management tools will provide the means of categorizing or tagging tests, which will make it easier for everyone on the team to identify and reference a certain type of test.


Prioritize Tests Based on Customer Needs: One useful way to prioritize tests is to consider the needs of the customer or user. Consider how a given test case impacts the end user’s experience or the customer’s business requirements.


Check out this article for more info: “Regression Testing: What It Is and How to Use It”


What Does “Website Performance” Actually Mean?


Load times vary dramatically from user to user, depending on their device capabilities and network conditions. Traditional performance metrics like load time or DOMContentLoaded time are extremely unreliable since when they occur may or may not correspond to when the user thinks the app is loaded.


~ User-centric Performance Metrics | Web Fundamentals | Google Developers


Nowadays, life cycle of a web page load can be thought of more granularly. We can think of website performance metrics as being “user-centric”. When a user goes to a web page, they’re typically looking for visual feedback to reassure them everything is working as expected.


The metrics below represent important points of the page load life cycle. Each answers questions about the user experience.


First Contentful Paint: Is it happening? Did the navigation start successfully? Has the server responded?


First Meaningful Paint: Is it useful? Has enough content rendered that users can engage with it?


Time to Interactive: Is it usable? Can users interact with the page, or is it still busy loading?


Long Tasks (absence of): Is it delightful? Are the interactions smooth and natural, free of lag and jank?


We can run performance audits manually or programmatically using tools like Lighthouse to provide values to metrics similar to the above. We can use a Lighthouse integration like Foo’s Automated Lighthouse Check to monitor website performance over time. In the example below you can see Twitter’s performance degrade and correlate it to an exact day and time! What if we could pinpoint this to an exact release? In the next section I explain how to do this.


Twitter Performance Degradation


How Can we Regression Test Performance Automatically?


We can accomplish automatic performance tests integrated as a post deploy step in a continuous delivery pipeline. We can do this by creating a free account with Automated Lighthouse Check and utilizing its public REST API. Follow the steps from the documentation to create a free account and obtain API tokens.



Trigger a test run by requesting the endpoint as detailed in the docs linked above. A curl command would look something like curl -X POST "https://www.foo.software/api/v1/queue/items" -H "accept: application/json" -H "Content-Type: application/json" -d "{ \"pages\": \"pagetoken1,pagetoken2\", \"tag\": \"My Tag\" }".


Add the above command as a post deploy step in your CD pipeline. Below a circleci snippet that actually defines this step.


From the example linked above our pipeline steps run on every commit to our master branch.


Continuous Delivery Steps


And voilà we are now deploying a release on every commit to master and running a performance audit on it automatically ⭐!


Conclusion


Automated Lighthouse Check provides many features to monitor and analyze performance. In this post we took a look into how we can utilize it to run Lighthouse performance regression testing automatically. Below are other features — most of which are free!


Automatic performance audits, a timeline visualization and detailed views of results.


Slack notifications when performance has dropped, improved or become “back to normal”.


Automatic health check pings and notifications.


Update (12/28/2019)


Many enhancements have been added to Automated Lighthouse Check since the writing of this article. Not only does it provide website performance monitoring, but now also SEO, accessibility, best practice and web app progressiveness. We’ve also added custom support for specific DevOps flavors reflected in our documentation.


Comments

Popular posts from this blog

How to choose which validator to use: a comparison between Joi & express-validator

   Envision you have  a web based business site and you're permitting clients to make accounts utilizing their name and email. You need to ensure they join with genuine names, not something like cool_dud3. That is where we use approval to approve information sources and ensure input information keeps specific guidelines. On the lookout, we as of now have a lot of approval libraries, yet I will analyze two significant approval libraries: Joi and express-validator for express.js based applications. This examination is valuable when you have chosen to involve outer info approval library for your application based on expressjs and are to some degree not certain which one to utilize. Who is what? Joi Joi permits you to make plans or constructions for JavaScript objects (an article that stores data) to guarantee approval of key data. Express-validator express-validator is a bunch of express.js middlewares that wraps validator.js validator and sanitizer capabilities. So by defin...

Products And Services Services Services And Products For The Automotive

    Although  the precise exact numbers required are difficult  troublesome  tough to determine to find discover out, the best one of the best the most effective calculations, considering contemplating both each the assembly meeting operation and the stamping of body physique panels, place the optimum output at between 200,000 and 400 four hundred,000 cars automobiles vehicles per year yr 12 months for a single plant. Increasingly stringent and costly and dear and expensive regulations laws rules aimed at aimed toward geared toward correcting environmental damage injury harm due to the because of the as a result end result outcome of rising number of variety of vehicles automobiles autos on the road street highway also have even have been a factor an element in the within the move transfer toward towards  consolidation . The automotive industry business trade comprises includes contains a wide broad extensive range a variety of companies corporations firms ...

What Is What's Computer Pc Laptop Hardware? Computer Pc Laptop Hardware Components Elements Parts

  Attempts to  standardize   this interface to enable allow the combination the mixture the mix of data of knowledge of information plane aircraft airplane components elements parts with control management plane aircraft airplane components elements parts from different totally different completely different vendors distributors have not haven't been particularly notably significantly successful profitable. In practice apply follow, this interface is based is predicated relies on proprietary specifications specs and implementations. Evolved toward towards more extra unified processors, it increasingly more and more resembled high-performance parallel computers computer systems. However, DirectX 9 GPUs had been designed only solely to match the features options required by the graphics APIs. To access entry the computational resources assets sources, a programmer had to needed to cast forged solid his or her problem drawback downside into graphics operations so that in ord...