DEV Community

Cover image for Why You Should Use Puppeteer For Testing
robinjangu for LambdaTest

Posted on • Edited on • Originally published at lambdatest.com

Why You Should Use Puppeteer For Testing

Over the past decade the world has seen emergence of powerful Javascripts based webapps, while new frameworks evolved. These frameworks challenged issues that had long been associated with crippling the website performance. Interactive UI elements, seamless speed, and impressive styling components, have started co-existing within a website and that also without compromising the speed heavily. CSS and HTML is now injected into JS instead of vice versa because JS is simply more efficient. While the use of these JavaScript frameworks have boosted the performance, it has taken a toll on the testers.

Testing and debugging has become more and more complex.
Puppeteer has been introduced as a node library to enable Chrome browser testing.

Starting your journey with Puppeteer Testing? Check out how you can test your Puppeteer test scripts on LambdaTest’s online cloud.

Headless Browser

As the name itself indicates, headless browsers are the browsers that run as a app process without any user interface elements. Headless browsers, like Headless Chrome are simply faster, consumes less memory, more flexible, and are steadier under automation stress.

Google has been working to ensure that proper support is provided for the DevTools ecosystem. With the use of Puppeteer, web crawling, scraping, and launching automated scripts can now be accomplished with less efforts, and more stability than before.

Automation Made Easy

Selenium leads the industry when it comes to automation testing. This wonderful open sourced tool has been accepted by the testing community with open hands. But and this is a big but, selenium testing requires installed browsers no matter whether the selenium is installed on cloud or on local machine. Add in the complexity of integrations with the variety of components it becomes too hard for the process to run smoothly.

Headless chrome has become the go to guy when it comes to using automated scripts into the browser. Use of Karma, Mocha, and Puppeteer along with it has all of sudden made testing using automated scripts easier.

Hey! Do you know the uppercase text tool, allows you to change all the lowercase letters to a capital letters. Simply copy and paste the text into the text area below and click the button. You’ll get all your text just as it was, except it’ll be in uppercase.

Visual UI Regression Testing

Puppeteer can be used for regression testing of various UI elements. To test the UI of the website it is advisable to have the latest chromium version to ensure better api control. Usually Mocha is used along with Puppeteer in order to have regressive testing on the various UI features. In addition Mocha provides you with hooks that can be used before or after testing.

Puppeteer is successful mainly because it simplifies the functionalities related to automated tasks performed on browsers.

Screenshot Testing

The ultimate trio of Jest, Headless Chrome, and Puppeteer can be used for screenshot based testing. In fact LambdaTest’s Automated Screenshot feature leverated all three of these tools to take screenshots across multiple chrome browsers. You can easily capture React trees and other serializable values and use them to analyze the state changes while testing. Jest comes with the powerful React ecosystem and its integration paves the way for the JavaScript elements to be tested with ease.

Puppeteer-screenshot-tester is a library in the puppeteer itself that allows screenshots to be generated while testing.

Similarly ava-puppeteer is another library that is available on GitHub that will soon be available on npm.

Chick this out: The Testμ (TestMu, pronounced as ‘TestU’) Conference brings together software testers, developers, influencers, and community builders to talk about the future of testing and the people behind it.

Performance Testing

Using Puppeteer, performance metrics can be measured and analysed in order to optimize the website for different devices and network speeds. Chrome provides DevTools that enable recording of the Performance Timeline that when automated reveals the problems associated with performance. Puppeteer is a high level API control over Chrome Developers Tools Protocol. The proficiency of Puppeteer to easily handle asynchronous elements and their behavior with respect to the DOM state change. You can even save the performance data as JSON file.

Put it like this when you use Puppeteer, you are the Puppeteer. You can exercise control over the service workers and test the caching as well as the loading time of a website with or without cache time. Website response time can be tracked using responseEnd, along with influence of network bandwidth and latency related issues.

Load Testing using Puppeteer

Load Test is simply accounting for the maximum number of instances that you can probably run on your site. Multiple Puppeteer instances can be launched parallely with ease through which you can load test the website under review.

*Load Testing*

Puppeteer is true to its name, as you have a heavenly command over your headless chrome with which you have the ability to launch a great deal of test instances on a single or multiple browser session.

$ puppeteer-loadtest — s=120 — c=40 — file=XYZ.js
Enter fullscreen mode Exit fullscreen mode

Here the –s is for the number of sample and –c is for the concurrent sessions per sample.

End to End Testing

End to end or Acceptance testing is often considered one of the least popular testing. Selenium was used earlier for acceptance testing, and it is quite error prone and has a lot of bugs. Then came Puppeteer with improved focus on the API control that helped disentangle the complications that came in the form of bugs. One of the superpowers of Puppeteer that it doesn’t need to know about your stack and can work with any framework, be it React, Angular or any other library.

Do you know? Text repeater prints repetitions of the input string as many times as specified. For each repetition, it prints the string in a new line.

Conclusion

The success of puppeteer and chrome can’t be reduced only to their efficiency, the fact that it is a Google backed is also the reason why it has been accepted and recognized globally. The biggest problem however is that it’s integrity with headless chrome is brilliant however with other browsers it may falter.

Having said that I strongly believe that this tool will flourish with the ever expanding google ecosystem. The future shines bright for Puppeteer.

Top comments (0)