This is an old revision of the document!


Tutorial: Load Testing with Runtime Servers

Virtual Users (VUs)

Virtual Users (VUs) is an important concept in load testing and stress testing with each VU representing one testing session.

In TestOptimal, VUs are implemented with separate processes (threads) to execute the test cases generated from the model.

A model is executed with one or many VUs. In the web application / website load testing, VU is used to simulate concurrent users.

Unlike typical load testing tool which submits pre-designed http packets or scenarios, TestOptimal can re-purpose models to dynamically generate test cases with the help of sequencers to simulate the more realistic production load on the system.

Model Execution with VUs

When you execute a model, it uses one VU by default. You can change the number of VUs to be used for model execution in the Execution Settings:

Set the field “Threads (VUs)” to the number of virtual users you wish to simulate running your AUT.

You can also change how fast you want to ramp up the VUs by setting the “Thread Delay (ms)” before starting next VU.

For load / stress testing, typically you will want the model and all of its VUs to be running for a desired period of time. You can do so by setting “Elapse Time (mins)” in “Model Execution Stop Conditions” section before running the model.

Multi-model execution

Each model describes a set of behavior (requirements, user stories) of AUT. By running the model, we are exercising and checking those behavior.

If you have more than one models created to test your AUT, you may want to run these models concurrently to expose your AUT to various types of activities described by these models.

You can do so by opening each model and run the models (with 1 or more than one VUs). As you open another model, be sure do not close the previous model.

Load testing with multi-browser

Selecting which browser to use to run load testing is done in the scripts, for example:

 $SELENIUM.setBrowserFirefox();
 

You may replace above script with the following to randomly choose a browser to run the testing for each VU:

 $SELENIUM.setBrowser ('Firefox|IE|Chrome');
 

If you wish to have more “Firefox” users, you can just list “Firefox” twice or three times, for example:

 $SELENIUM.setBrowser ('Firefox|Firefox|IE|Chrome');

If you run the models through SvrMgr or use API to run models on Runtime server, you may select browser from a variable that is specified in the model execution request:

 $SELENIUM.setBrowser ($VAR.browserList);

where “browserList” variable is set in the model execution request options.

Load testing with Runtime Servers

Load testing with cloud-based services

Simulating production load

The first step in load testing is to determine the type of loads and how much you wish to exercise on AUT. Typically you would already have suite of models created for functional testing of AUT. These models when executed generates a specific type of loads on AUT.

Carefully select a subset of these models that will generate the type of loads required and determine the number of virtual users for each selected models. You may use the following example to help you plan your next load testing:

  Model Nam           MCase             VUs   Run Duration (min)   Thread Delay (ms)
  WebStore Security                      20        60                   15000 
  WebStore Main                         300       120                    5000 
  WebStore Main       Quick Purchase     50        60                   10000 
  WebStore Main       Add/Remove Items   20        60                   10000     
  

Note that in the above example, we are using two models:

  • WebStore Security - security testing for user registration and valid / invalid logins.
  • WebStore Main - main functional testing of WebStore application

We also plan to run certain scenarios (MCases) during the load testing.

Performance testing