20i
Web Page Speed Testing

How To Optimise Your Website With Performance Testing

Performance testing is a widely used strategy in software and website development to understand how an app, website, API and database will behave under various conditions, and identify any bottlenecks in the system. 

Whether it’s seeing how your website responds to sudden surges in traffic or how well it copes with a specified load over time, there are many different tests you can use to ensure your website is optimised for any scenario. 

There are multiple stages to a website loading…

Backend (server) 

  • DNS Time – Nameservers pointing your browser to the IP of the website 
  • TCP connect time – TCP connection made to the server 
  • TLS connect time – TLS connection made to the server (SSL/TLS) 
  • Time to first byte – When the browser receives the first byte of data from the server (TTFB) 

Frontend (website) 

  • Base page time – Browser receiving the site’s HTML/XML 
  • First paint – The browser begins rendering pixels of the website 
  • First contentful paint – The browser begins rendering the website’s content (usually <svg>, <canvas>, text and background images) 
  • Time to visually ready – The last visual change has occurred and the website looks to be ready 
  • Onload – When all resources of the webpage are downloaded (CSS, images, videos etc.) 
  • Time to interactive – When the website is available for user interaction 
  • Fully loaded time – The webpage has fully loaded in the browser 

Taking the steps above into consideration can help you identify where a website’s slowness originates from.

Common Performance Tests 

Load Testing 

Load testing is the process of creating a simulated demand on your website to learn how it will cope under a specific condition – usually an expected, real-life data load. 

You can consistently raise the load during these tests over time to discover the current limit of your system.

This type of test usually includes volumetric data that will help you identify the limits that the website can handle as well as highlight specific issues that occur under certain conditions. 

Spike Testing 

Much like load testing, spike testing is used to understand how well your website can handle sudden extreme variations in traffic.

It allows you to test the performance under those conditions to check for any issues users may experience during peak times. 

Spike testing tools can simulate a sudden abundance of connections to test your website, API, application, database or store.

This can also be used to mimic a pseudo-DDoS attack, which will highlight the limit at which your website reaches before it suffers denial of service. 

Endurance Testing 

Large volumes of traffic can last for hours during peak times and cause real issues. 

That’s where Endurance Testing comes in. Similar to spike testing, it will generate a large number of sudden traffic, however, with endurance testing, this will be prolonged.

It helps you monitor your website’s performance under a specific load over an extended period of time, so you can rest assured that your site will run smoothly. 

Imagine that your e-commerce site releases a new product that is an immediate hit with your customers.

Your website suddenly sees a huge influx of traffic with no signs of slowing down anytime soon and your website is pushed to its limits.

Your website becomes overwhelmed and is rendered offline, resulting in a large loss of sales and also impacting how reliable your customers see your brand. 

Luckily, with 20i, our hosting platform is load-balanced with autoscaling technology. This means your website will be allocated more resources automatically or moved to its own dedicated backend to prevent any loss of performance or outages. 

Volume Testing 

Response times are one of the most important things for a website; no one likes waiting around nowadays.

If your TTFB (Time To First Byte) is high, the user will likely back out of your site before it has the chance to finish loading.

Sadly, many sites slow down to a halt when they experience huge volumes of data. TTFB is usually caused by how quickly the web server can send the first byte of data to a user.

Scalability Testing 

Your site may work well with a handful of users, but how well will the server cope when you scale up? You can find out with Scalability Testing.  

This form of performance testing is used to see how well your site can deal with both increases and decreases in demand, to ensure consistent performance in all scenarios. 

Stress Testing 

Stress Testing is a must if you want your website to be robust and reliable. It involves simulating a very high spike in traffic to exceed your site’s bandwidth, letting you determine where it will fail and whether it can bounce back afterwards. 

The Benefits Of Performance Testing 

Amazing User Experiences 

By testing your website’s performance and optimising it wherever you can, you’ll create an unforgettable user experience that your end-users will want to come back to time and time again.

It’s the single most important reason to take performance testing seriously. 

Improved Mobile Performance 

Mobile devices are impacted more by network conditions, which can affect performance.

With well-implemented testing, you can improve your website’s load times (even on the slowest networks) so your users don’t get frustrated. 

Guaranteed Performance 

Testing your website under all those different conditions listed above gives you confidence that it can withstand whatever may come its way.

Crashes and errors may still occur, but you will have minimised the risks of major failures way before they happen. 

The Performance Testing Process 

So, are you ready to get started with performance testing? Here are the main steps to follow. 

  1. Get your website fully functional – Performance testing comes when you have a working site. It must function properly to provide accurate and useful test results. 
  1. Strategize – Create a plan of action for your performance testing, including the scope, the tests you want to perform and the scenarios you will use. Don’t forget to decide what counts as a success either! 
  1. Perform the tests – Choose your performance testing software and use it to create test scripts and define the user actions you will be testing. Once you’re happy everything matches your strategy, you can run the tests. 
  1. Review – Analyse the test data to discover areas for improvement, then start to implement those changes. 

Performance Testing Tools 

LoadView by Dotcom-Monitor 

This is an on-demand, 100% cloud-based platform to load test web pages, web applications and web services/APIs.

We think it’s one of the best load-testing tools available.  Includes a free plan for single tests and paid plans starting from $129/month. 

For more information see: https://www.loadview-testing.com/ 

Apache JMeter 

A full suite of open-source performance testing tools. It works at the protocol level (not the browser) to test performance with both static and dynamic resources. 

You can download it for free at: https://jmeter.apache.org/ 

LoadNinja 

A user-friendly and accurate load testing tool that provides real-world accuracy and instant playback. Uses real browsers for reliable data. 

Plans start from $105/month. 

For more information see: https://loadninja.com/ 

Summary 

Performance testing is a valuable part of the development process that everyone should take seriously.  

Both software performance testing and website performance testing can help you judge the current performance, identify bottlenecks in your current system, and discover ways to improve your next version. 

Thanks to the range of software available (both paid and open source), it is also accessible to development teams of all sizes.

Managed Cloud Hosting

1 comment

  • The detailed explanation of backend and frontend metrics, along with the various types of tests, provides a solid foundation for anyone looking to optimize their website’s performance.

    The benefits highlighted, especially the emphasis on creating amazing user experiences, are a crucial reminder of why performance testing is so vital in today’s digital landscape. The step-by-step guide is a handy reference for both beginners and experienced developers. Appreciate the insights and practical tips!