DEV Community

Cover image for Basics Of Compatibility Testing
Dileep Marway for LambdaTest

Posted on • Originally published at lambdatest.com

Basics Of Compatibility Testing

Compatibility testing is checking if the software is capable of running on different hardware, operating systems (OS), applications, network environments, or mobile devices.

It is a key part of a QA strategy and if this has not been thought of in your approach I would recommend that you do some research and make it a key part of your approach.

Given that there are a large number of devices/browsers it is key that you have a strategic plan to ensure that compatibility testing is factored into your testing strategy. For me, compatibility testing is a form of not discriminating against devices/browsers that a particular user may use.

A comprehensive UI testing tutorial that covers what UI Testing is, its importance, benefits, and how to perform it with real-time examples.

Why is compatibility testing important?

Far too many times I have used websites on my iPhone where I cannot buy the product that I want to buy, or I’m on my MacBook and a website cuts off the right-hand side on the Safari browser.

I’m sure we have all been frustrated in these ways before and it is an annoyance which hinders the user flow. As a customer I’m willing to spend more on a product if the website user experience aids the user flow.

Key reason why you should factor this in:

  • Ensures complete customer satisfaction

  • Provides service across multiple platforms

  • Identifies bugs during the development process and earlier than customers!

  • Avoids customer complaints.

  • Ensures a competitive advantage

Types of compatibility tests

  • Hardware

  • Operating system (OS) — such as Windows, Unix, MacOS

  • Software — e.g. ensuring that MS word is compatible with MS outlook

  • Network

  • Browser — for instance: Firefox, Google Chrome, Internet Explorer

  • Devices

  • Mobile — android and iOS

  • Version — e.g. Windows 7, Windows 7 SP1

Key terms mentioned around compatibility:

  • Backwards compatibility — this is where you are testing to see if your software is compatible with previous versions.

  • Forwards compatibility — this is where you are testing to see if you software is compatible with versions which will be coming in the future.

In this tutorial on Agile testing, let’s deep dive into the history of Agile Testing, its advantages, disadvantages, methods, quadrants, and best practices.

Steps to fit in compatibility testing in your testing approach

  • Define a set of environments or platforms the application is expected to work on.

  • Gather customer data on how your customers use your products.

  • Understand the expected behaviour under different configurations.

  • Setup your environment and get the particular device permutations ready.

  • Report any bugs that are found.

Step 2 for me is super important and it is one where I do not feel enough people build into their plan.

To gather customer data on how your customers use your products I would recommend that you set-up google analytics or an alternative type of statistical analysis system.

For example when we had a website product, this data allowed us to know what browsers and OS versions our customers were using. Using this we could then tailor our test cases to ensure that the product functionality met the users needs.

Another game changer with this data is that it removes bias, many a time I have assumed that a latest device will be the most used by a user base, though when I received this data I actually learned that users generally used the latest device which was from a year before.

What are the common compatibility issues found

  • Changes in the users interface (UI)

  • Change in font size

  • Alignment issues

  • Change in CSS style and color

  • Scroll bar related issues

  • Content or label overlapping

  • Broken tables or frames

Why you should use a compatibility testing tool?

The biggest concern around compatibility testing is that there are so many different test cases which need to be tested constantly, and if we are making key architectural or code changes the ability to release at pace becomes near enough impossible.

So how can you build compatibility testing into your test approach and still release at pace?

The answer to this has been to use a compatibility testing tool — now there are lots on the market, though my recommendation is to do your research and take your time to pick the right tool.

In this Ad hoc testing tutorial, let’s deep dive into what Ad hoc testing is, its advantages, disadvantages, types, characteristics, and their best practices.

Key considerations for me when selecting a compatibility tool include:

  • Price

  • Usability of the tool

  • Device availability when you need to test on it

  • Availability of older/never devices and different browsers

  • The ability to incorporate the tool with your automation pack

My personal recommendation is LambdaTest, primarily because:

  • It supports more than 3000+ browsers and operating systems.

  • It allows live interactive browser compatibility testing.

  • It is cost effective and has great customer service.

  • The devices are readily available.

  • Allows integration with an automation framework.

Incorporating a compatibility tool with your automation framework is a game changer and this is a key consideration when you are at a stage where you are confident that you understand why you are testing for compatibility.

My closing statement is that if you do not have compatibility testing built into your testing approach it can be a game changer to your users and I would recommend that you add it as soon as possible!

Top comments (0)