Dies ist eine alte Version des Dokuments!


Internal reference: topics/06-2.md

Popular JavaScript frameworks can use Facebook’s Jest to perform unit tests. Jest has the Coverage Report feature that allows us to check if our code covers all lines of the files we choose by generating an HTML file that we can open.


  1. Statements represent instructions that have been executed at least once during the unit tests. For example, we can have a line that contains two statements:
var age= 18; console.log(age)

This contains a variable declaration statement and a statement that executes the log function that belongs to the console object.

  1. Branches represent if statements which conditions have been fulfilled at least once during the unit tests.
  2. Functions represent functions that have been called at least once during the unit tests.
  3. Lines represent code lines that have executed at least once during the unit tests.


Seeing your code coverage can be as simple as adding the –coverage flag when running your Jest unit tests:

jest --coverage

After you run the coverage command you’ll get a summary report that looks like this:

Fig-01: Code coverage in Jest on the terminal.

By adding –collectCoverageFrom, Jest will calculate code coverage for all the files that you specify. Even ones without any tests:

jest --coverage --collectCoverageFrom='src/**/*.js'

Fig-02: Code coverage for all files.


When looking at the summary table, it can be very hard to determine where you are missing coverage! A much easier way is to generate an HTML report in the folder you specified with –coverageDirectory:

jest --coverage --coverageDirectory='coverage' --collectCoverageFrom='src/**/*.js'

Fig-03: Code coverage in Jest in the browser.

If you open up the index.html file in your browser, you will see lines highlighted in red. These are the lines that are not currently covered by your unit tests.


If you open up the index.html file in your browser, you will see lines highlighted in red. These are the lines that are not currently covered by your unit tests.

Fig-04: Drill down of the report.

By analyzing the lines of code we can see 1x on the left hand side. It means that we executed that part of the code one time during our unit tests. This happens because I only tested one of the functional requirements on my unit tests.

The I symbol at line 7 means that this branch has not been entered during unit tests (if path not taken). Similar is the E symbol at line 13 means that alternative branch has not been entered during unit tests (else path not taken).

If there is a part of line that is highlighted in yellow, it means that the possible branch is not covered.


As you increase your code coverage, sometimes it will be too hard to cover certain lines of code with unit tests. Spending your time trying to find a workaround to cover that line of code is never worth it. There are much better things you could be spending your time on than striving for 100% coverage!

Even if you do cover a line of code, there's no guarantee that it will be perfect and bug-free, either. If we take a look at a double function that doubles the number you pass in:

const double = (number) => 2;

You could test that double(1) = 2 and that test would pass. You would have 100% code coverage as well. But your function would fail with all other numbers.

Code coverage is useful, but it's important not to use it as the only metric to measure your unit tests. Make sure to keep in mind all the possible edge cases and different scenarios, as code coverage won't pick these up.


Daniel Garavaldi

  • en/modul/m324_aws/topics/10.1760530450.txt.gz
  • Zuletzt geändert: 2025/10/15 14:14
  • von dgaravaldi