JS code coverage with selenium tests

2.4k views Asked by At

I’m new to the entire concept of capturing JS coverage. The way I intend to use JS coverage tool is to check how many lines of my JS code is being hit by my tests running in a browser, thus using code coverage to improvise my test coverage. Can somebody guide me to an example/tool of how to capture JS coverage for the test running using selenium webdriver.

3

There are 3 answers

3
mackowski On

You can try JSCover in manual you can find how to integrate it with selenium.

0
chintan On

keep generated .json file in .nyc_output directory then run below command. nyc report --reporter=html

reference https://istanbul.js.org/docs/advanced/coverage-object-report/

0
user378380 On

A tool like nyc is what you need. Take your js file(s) and run something like

nyc instrument

on them and nyc will modify the js files to record coverage. Use these modified files in your website. Then run your selenium tests. At the end of the selenium test, you need to capture the data from the JS files and save it to a json file. I use this code for that.

IJavaScriptExecutor js = (IJavaScriptExecutor)driver; string coverageData = (string)js.ExecuteScript("return JSON.stringify(window.cov_h0rgge4zy);"); File.WriteAllText(@"C:\someDir\coverage\" + DateTime.Now.Ticks + ".json", "{\"someFile\":" + coverageData + "}");

then run something like

nyc report html someCoverage.json

and you'll get the coverage report, html format