Knowledge Base > Diffblue Cover Reports 2.0 > 7. Visualisations in Cover Reports

Visualisations in Cover Reports


Cover Reports has many visualisations that simplify analysis of coverage data generated by the dcover CLI. Each visualisation is described in detail.

Where are the uncovered lines?

This is a sunburst chart which shows all elements in the project that have lines not covered by a test.

The rings represent the project hierarchy with the modules at the centre, then the packages, the classes and finally the methods on the outer ring.

Each ring is divided between the elements in the level. For instance, the methods ring will show all methods with uncovered lines.

The size of each segment indicates the proportion of uncovered lines within the level.

The number of uncovered lines is shown in the centre for the selected element in a ring. It is also shown as a percentage of the total of uncovered lines. Therefore, the methods will show the lowest proportions.

Here is an example where the TicTacToe class is highlighted. This is part of the ** com.diffblue.javademo** package in the current module module. It has 32 uncovered lines out of a total of 54 in the project, which is 59.3%.

Filter the results

The elements shown in the sunburst can be reduced to allow fine-grained visibility. This is useful when the project is large and produces a chart that has a large number of segments. In this case the segments can appear very small. Anything that is less than 1% will show as a white segment, which is indistinguishable from the background.

To use the filter, type a term that you want to see the detail on in the Filter Text field and press the Apply Changes button that will appear.

The filter term is not case sensitive and can appear anywhere in the element name.

Here a filter has been applied for prime, which gets both the Primes class and the getMillionthPrime method.

Viewing different coverage runs

Only a single dcover run is shown in the chart. To change the run use the Select Run select list and press the Apply Changes button that will appear.

How many lines are covered?

These are stacked bar charts showing the lines covered for each element.

There are several types:

  • Coverage by package: lines covered for each package in the project
  • Coverage by class for the run: lines covered for each class in the project
  • Coverage by method for the run: lines covered for each method in the project
  • Coverage by class for the package: lines covered for each class in the package
  • Coverage by method for the class: lines covered for each method in the class

Here is an example of the Coverage by class for the run chart:

Each chart shows how the lines in each element are covered. There are 4 line coverage types:

  • Not covered
  • Covered only by manual tests
  • Covered only by Diffblue tests
  • Covered by both manual and Diffblue tests

The sum of all the types is the total number of lines in the element.

When hovering over these charts, you can see the specfic element that is affected as well as the amount of its lines that are covered. In the menu displayed in the top-right of the chart, you can also choose to view all coverage types, or only the coverage type that you have hovered over.

These charts can be zoomed to examine greater detail and each line coverage type can be enabled or disabled as required to aid analysis.

The following example shows only lines not covered and lines covered only by Diffblue.

Run Coverage Sources

Run coverage sources is represented by a pie chart.

This pie chart is, by default, split into 6 sections which each represent how the code is covered by tests. These sections are:

  • Covered by both Diffblue & manual tests
  • Covered by Diffblue tests only
  • Covered by manual tests only
  • Not tested
  • Untestable
  • Trivial

The percentage displayed on the section of the pie chart represents the lines of code covered by that test source as a percentage of overall lines in the module.

The user can also hover over any section to get the raw amount of lines covered by that test source.

Here is an example of the Coverage sources pie chart where the “Not tested” section is hovered over:

Within this chart, the user can also click on a source within the legend to disable that section from the pie chart.

The remaining result would be a pie chart that represents how code is covered, as a percentage of total lines in the module minus lines covered by disabled sections.

For example, below is the same chart, but with the “Untestable” and “Trivial” sections disabled:

Output codes

When DCover runs, if there is a problem with a method that hinders test creation, an output code is provided. In these cases, methods can be left with uncovered lines.

This relationship is shown in several charts:

  • Output codes with uncovered lines for the run
  • Output codes with uncovered lines for the package
  • Output codes with uncovered lines for the class

The colours of the items in the charts are arbitrary.

Here is an example of a chart showing the output codes for a run:

This shows that there are:

  • 48 uncovered lines associated with R004
  • 13 uncovered lines associated with R013
  • 6 uncovered lines associated with R010
  • 2 uncovered lines associated with T006
  • 9 uncovered lines associated with R002