Optimizing Web UI load testing for scalability
Scalability denotes the number of virtual users that can be emulated on an agent machine to generate load. In a Web UI load test, each virtual user requires one instance of a web browser to be run. Because each instance of a browser consumes key computer resources such as memory, CPU and Network data, you must tune a few of the parameters to comfortably run appropriate number of browser (virtual users) on an agent machine.
Operating System | Red Hat Enterprise Linux 6.6 |
---|---|
System main memory | 4 GB |
Free memory before test run | ~3 GB |
Firefox (empty) memory consumption | 130 MB |
Firefox (medium-size app) main memory | 200 MB |
Tuning parameters
By default, the playback process of the Web UI test creates a thread pool of size 10 threads. This behavior affects the execution time when more than 10 virtual users per agent machine are emulated. This limit can be improved by passing the =-DrptDynamicThreads parameter to the agent machines.
Also, the Web UI test playback is a java process with maximum memory limit set to 512MB through the –Xmx argument. This parameter might yield more memory for browser instantiations.