Performance testing before go-live a worthwhile practice?

Listen on the go!

Is Performance testing before go-live a worthwhile practice?

For every performance testing professional and purists out there that have been religiously practicing proactive performance testing before go-live, is this not a sacrosanct question?

And we can expect that they would invariably react by letting us know of numerous examples in the past of how they have been able to proactively identify performance issues before go-live that resulted in better utilization of hardware and improved customer experience. Over and above, how they have managed to protect the brand from being tarnished, or it might also be improved sales as examples of benefits due to this proactive approach.

Of course, the benefits of proactive performance initiatives far outweigh when compared to practices of “throwing more hardware to solve application performance problems” but how relevant is this practice in the age of

  • DevOps methods to software delivery, where the expectation is to deliver new capabilities at supersonic speed?
  • Cloud adoption where additional hardware can be provisioned by simple policy/rule
  • New deployment strategies that can control deployments to services, servers, and users
  • Our inability to establish test environments at the right scale or size to reflect the application eco system complexity
  • New observability tools that can aid accelerated diagnostics so that root cause can be identified quickly, when coupled with DevOps methods of delivery changes can be pushed and tested swiftly in production than in test environments

Having implemented a CI/CD pipeline in their processes, a few clients also question if there is a need to do performance testing as they can release any fixes to production when they arise. Why should they invest money in proactive performance testing when they can get issues fixed in production faster than before? As the applications are also migrated to the cloud, is it bringing any value to the table by pitching in early performance testing when we can take the op-ex route to effectively maintain our applications in the cloud?

So, for all practitioners out there, the obvious question that invariably needs to be answered is: what is the right “timing” to conduct performance tests and assessments?

  1. Start early
  2. Before go-live
  3. Shift right: After go-live
  4. Shift right: Use observability platforms to conduct RCA and fix issues
  5. No need to test, throw more hardware
  6. All
  7. None

We think there is no silver bullet answer that we can adopt to get the performance risks mitigated.

The answer needs to be framed by considering Organization context and culture, Budget spend versus Risk appetite, Business criticality versus Brand identity, Delivery practices maturity, Technology adoption curve, and the Timelines to market introduction.

All these above factors will determine how an organization reacts to this new challenge of testing “early” versus “late” or “No-test” versus “Quick diagnose and fix” rather than investing in long cycles of performance testing before go-live.

There is definitely no single approach that can be termed better than the other. You may have to opt for a context specific approach that entails performance engineering practices that are apt for that context balancing risks, time and costs.

Conclusion

Cigniti has built a dedicated Performance Testing CoE that focuses on providing solutions around performance testing and engineering for our global clients. We focus on performing in-depth analysis of client’s context and provide a holistic approach that can range from practices at the component level, dynamic profiling, capacity evaluation, testing and reporting to help isolate bottlenecks and provide appropriate recommendations.

Cigniti’s contextual “performance engineering framework” enables clients with services that can deliver end-to-end testing & engineering, while our “analytics-driven workload modeler” helps avoid all workload modeling hassles. We maintain a dedicated pool of resources with expertise in a wide range of tools, technology stacks, and processes.

Cigniti teams follow a robust contextual Performance Testing methodology to test applications

Cigniti has had over 100 + Performance Test engagements, providing 40% to 70% savings on costs and over 50% efficiency gains. The common apps that we test are http, https, XML, SOAP, Java-based protocols, FTP, User Interface, headless etc…

We have strong partnership with vendors, that helps our clients choose the right tool based on their requirements and budget.

Need help? Talk to our Performance Testing experts to learn more about the right “timing” to conduct performance tests and assessments.

Author

  • Rajesh Sarangapani

    Rajesh Sarangapani is Senior Vice President, Global Delivery at Cigniti Technologies. With over 2 decades of experience, Rajesh has been instrumental in helping clients implement processes that helped them build application performance by design rather than as an afterthought. He holds a couple of patents to his name in the testing space and is a prominent speaker at various conferences, events, and webinars on software testing.

Leave a Reply

Your email address will not be published.