Performance Testing in the Real World
By Jeff Gainer
(Author's note: This essay originally appeared in the 17 May 2000 issue of the Cutter IT Journal E-Mail Advisor.)
Several years ago, while a software development lead, I was introduced to the concept of automated software testing.
Just point, click, and record the test cases, the vendor promised. Their tool would, we were told, quickly accumulate
a huge collection of automated test cases that would dutifully execute unattended. I was busy with my development
team and didn't have time to inquire in detail while the testing consultants merrily clicked, pointed, and recorded.
They planned to execute a suite of test cases over the weekend. Along with everyone else, I confidently left for
a long weekend, sat on the balcony at my lakeside hotel suite, lazily watching the sun set while I sipped exotic
cocktails, serene in the knowledge that 2,000 miles away, the computers were busily executing test cases.
I returned to the client office on Monday morning - late, like everyone else who had to fly in - and found that
something had gone wrong, there weren't any test results, and that automated software testing wasn't all that had
been promised. Still, I was intrigued by the concept, and over the next few years, gravitated toward automated
software testing, discovering that it was considerably more complex than the marketing folks had promised.
Today, with the advent of e-commerce, automated performance testing is the relatively new technology, and many
e-business companies are discovering that buying a tool is just the beginning of a successful performance testing
effort.
Training
Regardless of what the slick marketing brochures promise, there is more to automated performance testing than pointing,
clicking, and recording. Performance testing tools are complex, robust programming tools, so no matter how busy
your people might be, at least send them to a training class. Better yet, bring a trainer to your organization
to conduct classes and then spend some time with your staff, answering their specific concerns and mentoring them
in their new tools.
Planning
It's a given that planning is the most important step in software testing, and nowhere is this more true than in
performance testing. Work with your marketing people to create real-life user scenarios, then tap the system administration
and security staff to build scenarios to test possible areas of vulnerability. Then take this a step further: for
an online retailer, double or triple the holiday sales projections and see how the system reacts. An online stock
brokerage might develop a scenario for a market panic (replicating, say, five billion shares traded on the New
York Stock Exchange) to see how the system fares under that load.
Test Environment
Unless you're willing to bring down a live site, don't even think about testing against the production environment.
Better to build a testing laboratory - but make sure it reflects, at least in some measure, the production environment.
If you are testing a site before going live, test early enough so that the systems staff can revive it in time
if the site caves in under your tests.
Performance Testing is an Ongoing Project
Performance testing is not just a one-time endeavor to verify that your current system capacity is adequate or
to verify that a new site will be robust before going live. E-commerce is only in its early stages; even the experts
are still learning lessons about increased input from new markets, buying surges, and hacker, virus, and worm crises.
--Jeff Gainer
______________
(c)2000 Cutter Information Corp. All rights reserved. This article has been reprinted with the permission of the publisher, Cutter Information Corp., a provider of information resources for IT professionals worldwide.
This article originally appeared in the Cutter IT E-Mail Advisor, a supplement to Cutter IT Journal. www.cutter.com/itjournal