Parallel Testing: The Essential Guide

Give your users a seamless experience by testing on 3500+ real devices and browsers. Don't compromise with emulators and simulators

Get Started free
Guide Banner Image
Home Guide Parallel Testing: The Essential Guide

Parallel Testing: The Essential Guide

With the rise of CI/CD, QA teams must catch bugs early by expanding test coverage through automation. Parallel testing enables simultaneous execution across multiple configurations, saving time and costs while ensuring quality.

Overview

Parallel testing is a testing methodology where multiple test cases are executed at the same time. This approach ensures faster feedback, helps detect issues early, and optimizes the use of computing resources. It’s particularly valuable in large projects where test suites can become time-intensive to execute sequentially.

Benefits of Parallel Testing:

  • Reduced Execution Time: By running tests simultaneously, teams can achieve quicker results, enabling faster development cycles.
  • Improved Resource Utilization: Parallel execution leverages hardware and virtual environments efficiently.
  • Enhanced Scalability: Ideal for large test suites and cross-browser testing, ensuring broader coverage in less time.
  • Early Bug Detection: Parallel testing allows for quicker identification of defects, leading to improved code quality.
  • Cost Efficiency: By minimizing execution time and optimizing resource use, parallel testing can significantly lower operational costs, especially in cloud-based testing environments.

What is Parallel Testing?

Parallel testing is a process of leveraging automation testing capabilities by allowing the execution of the same tests simultaneously in multiple environments. The goal of parallel testing is to reduce time and resource constraints.

Unlike distributed testing, where the different test components running in a distributed manner interact with each other, the parallel test approach is free from any such interaction.

How does Parallel Testing Work?

To better understand how parallel testing helps boost standard automation testing capabilities, let us take a simple example – an automated functional test of a signup form. To perform this test for 45 different browser/OS configurations, with each test taking an average time of 2 minutes, the total run time of tests would be 90 mins or 1.5 hrs when run successfully in sequence.

Now imagine, when running 3 parallel tests simultaneously, the total execution time would have come down to 30 mins.

Running Tests Sequentially

And for 6 parallels, it would be even further reduced to 15 minutes – a far cry from what was expected before.

Running Tests Parallely

Considering this scenario to be one of the most basic functional tests that are automated, it boggles the mind how parallelization of tests can shave valuable minutes and hours from the most cumbersome of test suites.

Time Saved using Parallel Testing

The number of parallels required to optimize test times depends on the following key factors:

  • The current number of browsers (and/or) Devices on which the scenario needs to be tested
  • Number of parallel tests currently being run
  • Current Build Time
  • The desired number of browsers (and/or) Devices on which the scenario needs to be tested, and
  • Desired Build Time

For more complex scenarios involving a shift in any of these parameters, it is best to use a Parallel Test Calculator to understand the number of parallel sessions required to achieve test coverage and build execution time goals.

Advantages and Limitations of Parallel Testing

Now that it is discussed when and how to run parallel tests, let us look at some of its advantages and limitations:

Advantages of Parallel Testing

Speed: As demonstrated both theoretically and practically, sequential automated test execution is time-consuming. Parallel tests can speed up the process significantly as the same test is being run against different configurations at the same time.

Cost Efficiency: Creating, maintaining, and keeping test environments active need time and effort. However, these overheads are hardly a headache in parallel testing, and the required test environment can be leased when required and updated as per demands. Also, cloud-based test grids allow test execution at high concurrency, reducing the overall cost per test.

Optimization of CI/CD Processes: The effectiveness of a CI/CD pipeline is determined by its total run time. With feedback loops being of the utmost importance in CI/CD, the sooner the team has a result, the sooner they can apply the fix, refactor, and reiterate the process. Large test suites can be broken up into smaller independent jobs and run in parallel to quickly obtain results, thus improving the performance of the pipeline.

Parallel Testing Advantages

Limitations of Parallel Testing

  • For the parallel testing of different modules, we need to create independent modules. Also, modules with dependencies cannot be included in the parallel approach.
  • For parallelization, one needs to have a detailed understanding of the product and its flow for better results. Even though parallelization can help in cross-browser compatibility testing, its coverage of multiple browsers is restricted until and unless it is accompanied by distributed testing where the setup of multiple machines and browsers is provided.

When to perform Parallel Testing

Now that we have some inkling of how parallel testing works and how it can optimize test execution time frames let’s have a look at certain scenarios where parallel test execution is ideal:

  • In case the software engineering team is uncertain about the functionality of an application across devices and configurations, especially in regression-like scenarios with an updated version of an app.
  • In a case where legacy data is imported from an older system to a newer one, Parallel tests can be immensely helpful to check if everything has been moved across seamlessly using an automated regression test suite.
  • For cases of automated browser testing, when an app needs to be tested across different combinations of browsers, OS, and devices.

Try Parallel Testing on BrowserStack for Free 

How to approach Parallel Test Creation

A common way to perform parallel testing is to create a suite of projects to test browser compatibility and then a master project to test the aforementioned set of projects. Upon set up, it is time to create a set of Entry and Exit Criteria.

For Entry Criteria, we must define those checkboxes that must be ticked off before test execution starts, for e.g.

  • Set up a suitable test environment, for instance, Selenium with TestNG
  • Define the pre-conditions and test scenarios for the automated browser test process
  • Migrate any new and legacy data required

The exit level criteria can focus more on:

  • Understanding the difference in terms of test suite execution impact
  • Measuring the output of a new system as compared to a legacy system (if applicable)

Parallel Testing using TestNG and Selenium

TestNG is a Java-based testing framework that helps to organize tests in a structured manner and enhances the maintainability and readability of test scripts. The large feature set of TestNG allows for the easy configuration of parallel tests. The auto-defined XML file in the TestNG framework allows testers to set the parallel attributes to methods/tests/classes by leveraging the allowance for multithreading in Java. This file can help determine the number of threads desired for parallel test execution.

<suite name="Parallel_Testing" parallel="methods" thread-count="2">

The parallel attribute can be extended to:

  • Methods: To run methods in separate threads
  • Tests: To run all methods sharing the same tag in the same thread
  • Classes: to run all methods belonging to a class in a single thread
  • Instances: to run all methods in the same instance in the same thread

Whereas the thread count attribute can help define the number of threads the tester wishes to create when executing the tests in parallel.

The below code snippet helps to demonstrate parallel test execution for opening the BrowserStack homepage using two methods. One of the methods performs this action on Google Chrome, whereas the other does so on the Firefox browser.

import org.testng.annotations.AfterClass;
import org.testng.annotations.Test;
import org.testng.annotations.Test;
import java.util.concurrent.TimeUnit;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;
import org.openqa.selenium.edge.EdgeDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.openqa.selenium.ie.InternetExplorerDriver;
import org.testng.annotations.Test;

public class ParallelTestWithMultiThread {

WebDriver driver;

@Test()
public void testOnChromeWithBrowserStackUrl()
{
System.setProperty("webdriver.chrome.driver", ".\\Driver\\chromedriver.exe");
driver=new ChromeDriver();
driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
driver.get("https://www.browserstack.com/");
driver.manage().window().maximize();
System.out.println("this is the test related to chrome browserstack homepage"+ " " +Thread.currentThread().getId());

}

@Test()
public void testOnChromeWithBrowserStackSignUp()
{
System.setProperty("webdriver.gecko.driver", ".\\Driver\\geckodriver.exe");
driver=new FirefoxDriver();
driver.manage().timeouts().implicitlyWait(10, TimeUnit.SECONDS);
driver.get("https://www.browserstack.com/users/sign_up");
driver.manage().window().maximize();
driver.findElement(By.id("user_full_name")).sendKeys("<name>");
driver.findElement(By.id("user_email_login")).sendKeys("<login email id>");
driver.findElement(By.id("user_password")).sendKeys("<password>");
System.out.println("this is the test related to chrome browserstack login"+ " " +Thread.currentThread().getId());

}

@AfterClass
public void close()
{
driver.quit();
}
}

The TestNG XML file below helps to set up the parallel attribute as well as the thread count for the task.

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE suite SYSTEM "https://testng.org/testng-1.0.dtd">
<suite name="Suite" parallel="methods" thread-count="2">
<test name="Test">
<classes>
<class name="ParallelTestWithMultiThread"/>
</classes>
</test> <!-- Test -->
</suite> <!-- Suite -->

Once we are done with the execution, the TestNG report will look something like this

Parallel Test Execution in Selenium and TestNG

A clear sign of the time savings obtained from parallelization can be seen below, in the real-time result, where we can see that parallel test execution is quicker by almost 1.5 times than serialized test execution

Serialized Test Execution Serialized Test Execution Time

Parallel Test ExecutionParallel Test Execution Time

Running MBUnit tests in Parallel on Browserstack Automate

BrowserStack Automate can enable users to leverage the power of MBUnit to run tests across various browser, device, and OS configurations in parallel.

For test execution, the steps are as below –

1. Clone the mbunit-browserstack repo on GitHub git clone https://github.com/browserstack/mbunit-browserstack.git

2. Open MBUnit-BrowserStack.sln in Visual Studio
Configure the credentials required and the details of the browsers/devices for parallel testing in the App.config file within the mbunit-browserstack/MBUnit-BrowserStack/ directory

3. Understand the ROI from automation and get buy-in from the stakeholders

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="capabilities">
<section name="parallel" type="System.Configuration.AppSettingsSection, System.Configuration, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</sectionGroup>

<sectionGroup name="environments">
<section name="chrome" type="System.Configuration.AppSettingsSection, System.Configuration, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
<section name="firefox" type="System.Configuration.AppSettingsSection, System.Configuration, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
<section name="safari" type="System.Configuration.AppSettingsSection, System.Configuration, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
<section name="ie" type="System.Configuration.AppSettingsSection, System.Configuration, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a" />
</sectionGroup>
</configSections>

<appSettings>
<add key="user" value="YOUR_USERNAME" />
<add key="key" value="YOUR_ACCESS_KEY" />
<add key="server" value="hub-cloud.browserstack.com" />
</appSettings>

<capabilities>
<parallel>
<add key="browserstack.debug" value="true" />
</parallel>
</capabilities>

<environments>
<chrome>
<add key="browser" value="chrome" />
</chrome>
<firefox>
<add key="browser" value="firefox" />
</firefox>
<safari>
<add key="browser" value="safari" />
</safari>
<ie>
<add key="browser" value="ie" />
</ie>
</environments>
</configuration>

4. Now the tests are ready to run in parallel on BrowserStack using the following simple steps:

  • Building the solution in Visual Studio
  • Executing the tests with the fixture parallel from Test Explorer.

5. Other capabilities can be added under the environments option as described below:

<environments>
<chrome>
<add key="browser" value="chrome" />
<add key="browser_version" value="latest" />
<add key="os" value="Windows" />
<add key="os_version" value="10" />
</chrome>
</environments>

BrowserStack Automate Banner

Best Practices of Parallel Testing

None of the advantages of parallel testing will be of any use; however if we fail to follow best practices-

  • Make autonomous tests: One test should not depend on the outcome of another, as parallel tests may not occur in any defined order.
  • Test one feature at a time: The major advantage of parallel testing is modularization. A test that encompasses many features defeats the purpose of failing fast which is absolutely key to CI/CD pipeline performance.
  • Avoid the use of static objects: Using static objects may prevent another test, running in parallel, from manipulating it.
  • Resetting the test data: Cross-contamination of data needs to be prevented by modular creation, usage, and tearing down of test data to ensure the test leaves the system the same way it entered it.

Conclusion

Owing to the need for having access to multiple platforms and browsers to run tests in parallel, the cost of compatibility testing with parallel testing increases. Also, we may come to a point where access to all browsers and versions may not be possible. BrowserStack provides access to numerous platforms and browsers with their corresponding versions on the cloud. One can run automated parallel tests and use multiple browsers and versions.

Using BrowserStack’s real device cloud that provides 3500+ real browsers and devices makes testing Agile with wider coverage. The cloud allows parallel testing and supports integrations with popular CI/CD tools such as Jira, Jenkins, TeamCity, Travis CI, to ensure streamlined Automation Testing. This would help in leveraging Parallel Testing for your CI/CD pipeline.

Talk to an Expert

Tags
Automation Testing Cross browser testing Types of Testing