Performance Testing : Few Takeaways…
You may have been working on functional testing of a software for while, you may be proficient in taking the help of tools and libraries like UFT and Selenium to ease your repeatable work but have you given any thought about non-functional testing? (like performance testing) Do you know how it is different from functional testing?
In this post, you will get insights into the learnings that I had while working on Performance Testing of software. This post will help you to understand some of the few skills required for performance testing. It will also give some insights about how to get most out of the JMeter ecosystem. Let me be explicit - I don’t claim to be expert in the field, I just completed more than a year working in performance testing for my current employer. Prior to this engagement, when I was working at my last employer I got introduced to Performance Testing and JMeter and I learned the basics concepts in 5 months along with my daily job.
Without delay, I will start with the list of things I learned.
-
In Functional Testing, output generally treated as PASSED or FAILED for particular experiment/test (By the way, writing test cases is not testing) but that is not the case with the Performance testing. Performance Tests are performed/executed from the objective to get information about AUT which can be used to devise future strategy about the work needs to be done. Results cannot be always treated as PASSED or FAILED.
-
More often, it can happen that Page load time up-to 5 to 10 seconds is acceptable in Enterprise software whereas, for end-user facing applications it is big No-No.
-
Great companies and great people treat performance as a feature of the application.
-
More importantly, entry-level folks treat Knowledge of tool that they use to create a load profile as performance testing. Only knowledge of JMeter or Load Runner does not make you a performance tester, It’s essential to know the tools because it is very hard to create required load manually without the help of tools but there are lot of other things which are equally important to be a performance tester. [Similarly, knowledge of Selenium, does not make you tester or a test-automation engineer]
-
Result Analysis and Resource monitoring using APM tools are important as creating Load profile which supposed to represent the real users.
-
Finding patterns in Response time and Resource utilization is a very important skill which can distinguish good performance tester with average performance tester. In a sense, stronger analytical skills and curiosity is a treat required for this profile.
-
Performance testing is not Performance engineering.
-
Having Knowledge of architectural component helps to identify the root cause, a component like a Load balancer and its algorithm, Caching Mechanism, Service discovery mechanisms, proxies and reverse proxies are like essential for most of the software we use. It’s important to understand why and when these components gets used.
-
Client-Side Testing is underrated in the industry. Of course, there are pioneers who has adopted it and promoting it for while. But there is no traction as it deserves. Link for Google Trend :
![Trends for term - Performance Testing, JMeter, Client Side Performance, Lighthouse Chrome, YSlow](/Performance-Testing-Few-Takeaways/Trend-For-Term-Performance-Testing-JMeter-Client Side Performance-Lighthouse-Chrome-YSlow.png)Last Year Trend for keywords : Performance Testing, JMeter, Client-Side Performance, Lighthouse Chrome, YSlow
-
YSlow, an extension that was developed around 8 years ago,which is also no more maintained, is something still being used and searched for client-side performance testing.
-
Yahoo! posted - Best Practices for Speeding Up Your Web Site long back, it’s still good as it was produced yesterday.
-
Comparison of the latest Performance tests results with a baseline and the previous result is going to take a huge amount of time, at least in JMeter ecosystem. Influx DB and Grafana together can be very helpful for collecting the results at runtime and doing the comparison.
-
In-Build JMeter functions and properties only can be used with Backend Listener, there is no way of storing the additional dynamic value in Influx DB. If you really want to store something in the Influx DB, think about using JSR 223 Listener as Influx DB support writing to DB over HTTP.
-
Debugging code in JMeter is not at all user friendly. You will feel this strongly if you come from the background of using sophisticated IDE like IntelliJ. Uou cannot help but curse the user experience of using JMeter.
-
Groovy is wonderful not only from the Performance aspect as compare to Beanshell Scripting but to ease of use. You can use online console for Beanshell and Groovy because it’s lot faster to check your code working or not instead of using in JMeter directly. I personally prefer local instance of Groovy console. You can download it here