Performance vs. Load vs. Stress Testing
Performance vs. Load vs. Stress Testing
Performance vs. Load vs. Stress Testing
Stress Testing
Here's a good interview question for a tester: how do you define performance/load/stress
testing? Many times people use these terms interchangeably, but they have in fact quite
different meanings. This post is a quick review of these concepts, based on my own
experience, but also using definitions from testing literature -- in particular: "Testing
computer software" by Kaner et al, "Software testing techniques" by Loveland et al, and
"Testing applications on the Web" by Nguyen et al.
Performance testing
The goal of performance testing is not to find bugs, but to eliminate bottlenecks and
establish a baseline for future regression testing. To conduct performance testing is to
engage in a carefully controlled process of measurement and analysis. Ideally, the
software under test is already stable enough so that this process can proceed smoothly.
From a testing point of view, the activities described above all take a white-box
approach, where the system is inspected and monitored "from the inside out" and from a
variety of angles. Measurements are taken and analyzed, and as a result, tuning is done.
However, testers also take a black-box approach in running the load tests against the
system under test. For a Web application, testers will use tools that simulate concurrent
users/HTTP connections and measure response times. Some lightweight open source
tools I've used in the past for this purpose are ab, siege, httperf. A more heavyweight
tool I haven't used yet is OpenSTA. I also haven't used The Grinder yet, but it is high on
my TODO list.
When the results of the load test indicate that performance of the system does not meet
its expected goals, it is time for tuning, starting with the application and the database.
You want to make sure your code runs as efficiently as possible and your database is
optimized on a given OS/hardware configurations. TDD practitioners will find very useful
in this context a framework such as Mike Clark's jUnitPerf, which enhances existing unit
test code with load test and timed test functionality. Once a particular function or method
has been profiled and tuned, developers can then wrap its unit tests in jUnitPerf and
Page 1 of 4
Performance Vs. Load Vs. Stress Testing
ensure that it meets performance requirements of load and timing. Mike Clark calls this
"continuous performance testing". I should also mention that I've done an initial port of
jUnitPerf to Python -- I called it pyUnitPerf.
If, after tuning the application and the database, the system still doesn't meet its
expected goals in terms of performance, a wide array of tuning procedures is available at
the all the levels discussed before. Here are some examples of things you can do to
enhance the performance of a Web application outside of the application code per se:
Use Web cache mechanisms, such as the one provided by Squid
Publish highly-requested Web pages statically, so that they don't hit the database
• Scale the Web server farm horizontally via load balancing
• Scale the database servers horizontally and split them into read/write servers and
read-only servers, then load balance the read-only servers
• Scale the Web and database servers vertically, by adding more hardware
resources (CPU, RAM, disks)
• Increase the available network bandwidth
Performance tuning can sometimes be more art than science, due to the sheer
complexity of the systems involved in a modern Web application. Care must be taken to
modify one variable at a time and redo the measurements, otherwise multiple changes
can have subtle interactions that are hard to qualify and repeat.
In a standard test environment such as a test lab, it will not always be possible to
replicate the production server configuration. In such cases, a staging environment is
used which is a subset of the production environment. The expected performance of the
system needs to be scaled down accordingly.
The cycle "run load test->measure performance->tune system" is repeated until the
system under test achieves the expected levels of performance. At this point, testers
have a baseline for how the system behaves under normal conditions. This baseline can
then be used in regression tests to gauge how well a new version of the software
performs.
Another common goal of performance testing is to establish benchmark numbers for the
system under test. There are many industry-standard benchmarks such as the ones
published by TPC, and many hardware/software vendors will fine-tune their systems in
such ways as to obtain a high ranking in the TCP top-tens. It is common knowledge that
one needs to be wary of any performance claims that do not include a detailed
specification of all the hardware and software configurations that were used in that
particular test.
Load testing
We have already seen load testing as part of the process of performance testing and
tuning. In that context, it meant constantly increasing the load on the system via
automated tools. For a Web application, the load is defined in terms of concurrent users
or HTTP connections.
In the testing literature, the term "load testing" is usually defined as the process of
exercising the system under test by feeding it the largest tasks it can operate with. Load
testing is sometimes called volume testing, or longevity/endurance testing.
Page 2 of 4
Performance Vs. Load Vs. Stress Testing
• a specific case of volume testing is zero-volume testing, where the system is fed
empty tasks
Examples of longevity/endurance testing:
• testing a client-server application by running the client in a loop against the server
over an extended period of time
Goals of load testing:
• expose bugs that do not surface in cursory testing, such as memory management
bugs, memory leaks, buffer overflows, etc.
• ensure that the application meets the performance baseline established during
performance testing. This is done by running regression tests against the
application at a specified maximum load.
Although performance testing and load testing can seem similar, their goals are different.
On one hand, performance testing uses load testing techniques and tools for
measurement and benchmarking purposes and uses various load levels. On the other
hand, load testing operates at a predefined load level, usually the highest load that the
system can accept while still functioning properly. Note that load testing does not aim to
break the system by overwhelming it, but instead tries to keep the system constantly
humming like a well-oiled machine.
In the context of load testing, I want to emphasize the extreme importance of having
large datasets available for testing. In my experience, many important bugs simply do
not surface unless you deal with very large entities such thousands of users in
repositories such as LDAP/NIS/Active Directory, thousands of mail server mailboxes,
multi-gigabyte tables in databases, deep file/directory hierarchies on file systems, etc.
Testers obviously need automated tools to generate these large data sets, but fortunately
any good scripting language worth its salt will do the job.
Stress testing
Stress testing tries to break the system under test by overwhelming its resources or by
taking resources away from it (in which case it is sometimes called negative testing).
The main purpose behind this madness is to make sure that the system fails and
recovers gracefully -- this quality is known as recoverability.
I'm sure devious testers can enhance this list with their favorite ways of breaking
systems. However, stress testing does not break the system purely for the pleasure of
breaking it, but instead it allows testers to observe how the system reacts to failure.
Does it save its state or does it crash suddenly? Does it just hang and freeze or does it
fail gracefully? On restart, is it able to recover from the last good state? Does it print out
meaningful error messages to the user, or does it merely display incomprehensible hex
codes? Is the security of the system compromised because of unexpected failures? And
the list goes on.
Page 3 of 4
Performance Vs. Load Vs. Stress Testing
Page 4 of 4