Load Testing with Playwright using Step UI
This tutorial shows you how to set up a browser-based load test using existing Playwright tests in the Step UI.
Get Step SaaS for free to follow this tutorialIn this tutorial, we will use a sample online store application based on OpenCart as our Application Under Test (AUT). To implement our load test, we will reuse existing Playwright tests written in Java that simulate a typical user visit to our application under test.
1. Check out the sample project
Clone the sample project from GitHub:
git clone https://github.com/exense/step-samples.git
Optionally, run the JUnit tests locally:
cd step-samples/keywords/java/demo-playwright-keyword
mvn clean compile test
Create the Keyword Package that will be uploaded to Step:
mvn clean package -DskipTests
After execution of this command, a JAR file named demo-playwright-keyword-0.0.0.jar is generated and located in the “target” directory of the project. This JAR file will be used in the subsequent steps of this tutorial.
2. Configure the load test in Step
Log in to the Step Portal, or sign up for free and create a Step Cluster with 10 [java, ui-automation] Agents, following this Quick setup guide.
Once you’ve scaled the Agents, click Open in Step to open the Step application and carry on with the tutorial.
2.1. Upload the Keyword Package
Upload the Keyword Package built previously. The Keyword Package contains the automation steps that will be integrated in our load test.
- Go to the Keywords section
- Click on the Upload Package button
- Select the “demo-playwright-keyword-0.0.0.jar” as the Package file
- Click Save
2.2. Create the Plan
Create a new Plan using the TestScenario template:
- Go to the Plans section
- Click on the New Plan (+) button
- Name the Plan, e.g. Load test OpenCart
- Select “TestScenario” as the Template
- Click Save and edit
2.3. Configure the load test
For our load test, we will create a ThreadGroup that will repeatedly execute a task on OpenCart to simulate high loads.
- In the Controls section of the Component tabs, click on the New ThreadGroup (+) button to add a ThreadGroup child to the Plan. Hint: use the filter function in the Component tabs to easily find controls.
- Select the Keyword “Buy MacBook in OpenCart” from the Keywords section in the Component tabs.
- Configure the ThreadGroup with the following parameters:
- Number of Threads: 10 So the ThreadGroup runs 10 threads in parallel.
- Number of iterations per thread: (empty): There should not be a limit on the number of iterations per thread;
- Maximum duration (ms): 600000: The ThreadGroup should terminate after a maximum of 10 minutes (600000 ms).
3. Run and analyze the test
3.1. Run the load test
In Step, click Start Execution and confirm in the opened modal.
3.2. Analyze the results
Once the execution has started, you will be redirected to the execution page.
In the Performance tab, you can explore detailed performance metrics:
There you’ll find all metrics relative to the transactions of your Playwright scripts:
- The execution time of our Keyword “Buy MacBook in OpenCart”
- No custom measurements were defined for this Playwright script sample. You may easily add some, following this documentation.
3.3. Review the transaction statistics
At the bottom of the Performance view, you’ll find an aggregation of performance metrics for the selected time frame:
This tutorial serves as a starting point for those interested in performing load tests using Playwright scripts. Step enables you to reuse automation artifacts across the whole DevOps cycle, and load testing is just one aspect of it. Further learning and exploration on performance testing, synthetic monitoring and robotics can be found in other tutorials and resources.
This article demonstrates how to connect Grafana to data generated by Step.
This article demonstrates how to set up distributed system monitoring using Keyword executions, and analyze the results as measurements.
This tutorial demonstrates how to automate interaction with Microsoft Office applications using the Office Interop Assembly.
This article provides documentation for how to integrate JUnit tests into Step.
This tutorial demonstrates how Step can be used to monitor services, availability and performance metrics.
This tutorial demonstrates how to utilize the AutoIt C# binding to automate interactions with Windows applications.
This article demonstrates the automation of mobile applications on Android using the Appium framework.
This article defines three Keywords which will be used in browser-based automation scenarios, using Step and Selenium, as general drivers.
This tutorial shows you how to efficiently set up a browser-based load test using existing Cypress tests in the Step automation platform.
In this short tutorial, we show how to quickly implement a simple browser-based load test based on Cypress scripts in Step.
This article explains Keywords in Step and demonstrates how to create simple ones.
This tutorial demonstrates the design, execution, and analysis of functional tests using the web interface of Step.
This tutorial will demonstrate how to use Step and Selenium to automate various browser tasks.
This tutorial demonstrates how to use Step and Cypress to automate various browser tasks.
This tutorial demonstrates how Selenium automation tests can be turned into full synthetic monitoring using Step.
In this tutorial, you'll learn how to reuse existing Cypress tests to quickly set up and run a browser-based load test using the automation as code approach.
In this tutorial, you'll learn how to reuse existing tests written with Serenity BDD and Cucumber for load testing.
This tutorial demonstrates how Cypress automation tests can be turned into full synthetic monitoring using the automation as code approach.
In this tutorial, you'll learn how to reuse existing Cypress tests to quickly set up and run a browser-based load test using the Step UI.
This tutorial demonstrates how to leverage existing Selenium tests to set up and execute browser-based load tests, following a full code-based approach.
This tutorial demonstrates how to set up a browser-based load test in the Step UI using existing Selenium tests.
This tutorial demonstrates how Playwright automation tests can be turned into full synthetic monitoring using Step.
This tutorial demonstrates how Cypress automation tests can be turned into full synthetic monitoring using the Step UI.
This tutorial will demonstrate how to use Step and Playwright to automate various browser tasks.
This tutorial shows how to distribute JMeter tests across multiple nodes.
In this tutorial, you'll learn how to reuse existing Playwright tests written in Java to quickly set up and run a browser-based load test using the automation as code approach.
This tutorial demonstrates how Playwright tests can be reused for synthetic monitoring of a productive environment in a DevOps workflow
This tutorial shows how to distribute Grafana K6 tests across multiple nodes.
This tutorial demonstrates how Playwright tests can be reused for synthetic monitoring of a productive environment in a DevOps workflow
In this tutorial you'll learn how to quickly set up a protocol-based load test with okhttp
Learn how to set up continuous end-to-end testing across several applications based on Playwright tests in your DevOps pipeline using Step
Learn how to quickly set up continuous browser-based load testing using Playwright tests in your DevOps pipeline
Want to hear our latest updates about automation?
Don't miss out on our regular blog posts - Subscribe now!