It is easy to measure code coverage when running unit tests. You will find a plethora of tools (free & commercial) with a variety of features for any programming language you may be using. You can integrate these tools as part of your pre-commit hooks (i.e. you will not be able to push your code to version control if the limits set for code coverage fall below the minimum limit set), and also as part of your CI builds (i.e. fail the build if the code coverage limit falls below the expected limit).
The reason capturing code coverage works easily for unit tests, and maybe integration tests, is that these tests run in isolation, directly on the code. You do not need to have the product deployed to any environment to run the tests to measure the coverage. I found these great resources you can check out to understand more about how code coverage works:
http://www.semdesigns.com/Company/Publications/TestCoverage.pdf
https://confluence.atlassian.com/clover/about-code-coverage-71599496.html
However, very frequently this question comes up - how can we measure code coverage of the API tests, or of the functional UI (e2e / end-2-end) tests? I remember this question coming up since the past 8-10 years at least. Every time, I have given the same answer because I have not come across, nor seen any better way of answering this question. It is time I wrote it down for easier access to others as well.
Solution #1
Preconditions:
A big criteria for the above strategy to work is to ensure the environment is isolated - i.e. NO ONE is using the environment (for navigating through the product, testing of any kind other than the tests being triggered to measure coverage).- Deploy the product-under-test to an isolated environment, and start measuring code coverage.
- Then trigger the API / UI tests,
- That will tell you how much code coverage is achieved by these tests.
- What are you trying to understand from the code coverage of your API / UI tests? What value will it bring to the team? How will it make the product better?
- Do you expect the code coverage of your API / UI tests to be similar / identical / better than the unit tests? IF yes, we need to have a different conversation about the Test Pyramid
Solution #2
However, I believe there is a better approach to this.
Based on the Test Automation Pyramid shown above, the API / Web Service tests and UI tests are business facing tests. In this case, it will add more value to measure what functional / component coverage the tests have.
With this approach, the code coverage from the Technology Facing Tests (Unit / Integration / ...) will focus on technical aspects of coverage, and the Business Facing Tests (API / UI) will focus on functional aspects of coverage.
When looked at together, this will give a better sense of understanding of the overall quality of the product.
Tracking Functional Coverage
So, how can we track functional coverage?
Unfortunately, there does not seem to be an out-of-the-box way to do this. But below is how I have implemented this before:
- I used cucumber-jvm in my test framework
- For each (end-2-end Test) Scenario, in addition to the tags required for the test (as per the test framework design), I added the following types of tags to the test:
- functional areas touched by the test
- components / modules touched by the test
- I used cucumber-reporting plugin to generate rich, html reports
- The beauty of the reports generated by cucumber-reporting reports is that I can now see for my test execution the different statistics of the tags when the tests ran.
- Below is an example for the cucumber-reporting github page:
- With this report, you can now get to know:
- the overall tag execution state for the complete test run
- the number of times the tag was run as part of how many test scenarios
- drill down into tag-specific reports as well
Why is the above report important?
As mentioned above, I am adding custom tags to each scenario - based on module / functionality / etc. If there is any critical functionality of my product, I would want to have more concentration of tests covering that feature / module, compared to others.
Another way to visualize the tag statistics is in form of tag heat maps. You want your critical functionality to have a good sized bubble in the heat map. Also, any small bubbles, or non-existing bubbles would mean you do not have coverage for that feature / module.
The above example is one of the easiest ways to implement feature coverage for API / UI tests. But it is very likely you are not using cucumber-jvm, and cucumber-reporting plugin. But if this approach makes sense to you, then you could very easily implement it in your test framework, using the constructs and features of that programming language and tools.
hi Anand thanks for the info . above images are not accessible .Please upload again . regards sree
ReplyDeleteThanks for bringing it to my attention. I re-uploaded the images. Can you please check again?
DeleteImages are appearing now - Thank you Anand
ReplyDeleteHi Anand , this is the problem even i have been grappling with from quite sometime. Your approach helps in shifting emphasis from code coverage to functional coverage which is a good way to look at the problem
ReplyDeleteHi Anand , thanks for sharing this, i have been looking for a solution to this problem.I also agree that we should be focusing on business requirements at UI/API layer and try to measure that instead of code coverage.
ReplyDeleteThanks @lucifer. Let me know how this approach works out for you!
Delete