In SonarQube what is the difference in meaning between the "Lines to Cover" and "Uncovered Lines" metrics?

15,523

"Lines to Cover" are the total lines in your "production" code that you should, in a so-called perfect world, have tests for. This is every line in source code files, which is not a comment, blank or similar non-code line.

In the real world, your tests will only cover some of these. The lines that are missed are the "Uncovered Lines".

In other words, you can express "Coverage" as:

"Coverage" = 100% - 100 * "Uncovered Lines" / "Lines to Cover"
Share:
15,523
TafT
Author by

TafT

I have always been interested in computers and started programming and coding websites while I was at college; which I then continued to do through university as well. I should focus on some more home projects but education and work always seem to take up most of my time and leave me without much desire to bash more code once I get home :-/ Education MEng in Electronic Engineering from the University of Surrey Background 2017 to present working as an Embedded Software Engineer (predominantly C++ & Go) for a railway equipment supplier. 2015 to 2017 working as a Software Engineer (predominantly C++ & Ruby) for a Telecommunications company. 2010 to 2015 as a Software Engineer (predominantly C++ & Ruby) for a NAS System company. 3 Years working as Hardware/Firmware Engineer for a GNSS Test Equipment company

Updated on June 05, 2022

Comments

  • TafT
    TafT almost 2 years

    I am looking at the Coverage report within the Measures tab of a SonarQube analysed C++ project. On that page my summary information is as follows:

    SonarQube Coverage Overview

    What are the differences between the "Lines to Cover" and "Uncovered Lines" metrics?

    I have looked on the sonarqube website's Metric Definitions page but the two entries there to do not help me.

    Lines to cover - Number of lines of code which could be covered by unit tests (for example, blank lines or full comments lines are not considered as lines to cover).

    Uncovered lines - Number of lines of code which are not covered by unit tests.

    The way that reads, I would expect that Uncovered Lines would be a higher count than the Lines to cover number, as the former might include blank lines. If sonarqube understood the code somewhat it might also exclude exception handling from the "could be covered by unit tests" number as well.

    The given numbers are clearly a reverse of that, so I must not be understanding the meaning correctly.


    I have some unit tests run as part of the CI system and their code coverage is compilated using both lcov and gcov. The lcov data is passed through genhtml to make separate coverage report which currently gives data in some cases, so I may have partial misconfiguration issue adding to the confusion.

  • TafT
    TafT over 5 years
    Oh, so Line to Cover is more similar to a Lines of Code (LOC) count. I was reading it as it is the number of lines that need to be covered (hence it being very similar to uncovered lines). Thank you for the clarification. I suggested an emphasis edit to make it so that it is really, really obvious what the part I read wrong actually means.
  • Julien H. - SonarSource Team
    Julien H. - SonarSource Team over 5 years
    Lines to cover are similar to ncloc (non commenting LOC). But not exactly the same. For example in Java, annotations, or interface declarations are counted in ncloc, but not in lines to cover.