1
0
mirror of https://github.com/pgbackrest/pgbackrest.git synced 2025-01-06 03:53:59 +02:00

Improve custom coverage report.

* Show all uncovered branch parts even when there are more than two parts per branch. This is the way gcc9 reports coverage so it needs to work even if it doesn't make as much sense as the old way.

* Show covered branches in functions where coverage is missing.  Showing just the uncovered branches can be confusing because it's not always clear how the coverage relates to the code.  By showing all branch coverage (+ or -) this correspondence is made easier.
This commit is contained in:
David Steele 2020-03-20 12:54:29 -04:00
parent 8af8029006
commit 787d3fd67b

View File

@ -408,11 +408,12 @@ sub coverageGenerate
} }
my $strBranchLine = sprintf("%09d", $stryData[0]); my $strBranchLine = sprintf("%09d", $stryData[0]);
$rhCoverage->{$strFile}{line}{$strBranchLine}{branch}{covered} = true;
if ($iBranchLine != $stryData[0]) if ($iBranchLine != $stryData[0])
{ {
$iBranchLine = $stryData[0]; $iBranchLine = $stryData[0] + 0;
$iBranch = $stryData[1]; $iBranch = $stryData[1] + 0;
$iBranchIdx = 0; $iBranchIdx = 0;
$iBranchPart = 0; $iBranchPart = 0;
} }
@ -420,10 +421,10 @@ sub coverageGenerate
{ {
if ($iBranchPart != 1) if ($iBranchPart != 1)
{ {
confess &log(ERROR, "line ${iBranchLine}, branch ${iBranch} does not have two parts"); confess &log(ERROR, "line ${iBranchLine}, branch ${iBranch} does not have at least two parts");
} }
$iBranch = $stryData[1]; $iBranch = $stryData[1] + 0;
$iBranchIdx++; $iBranchIdx++;
$iBranchPart = 0; $iBranchPart = 0;
} }
@ -434,6 +435,11 @@ sub coverageGenerate
$rhCoverage->{$strFile}{line}{$strBranchLine}{branch}{$iBranchIdx}{$iBranchPart} = $rhCoverage->{$strFile}{line}{$strBranchLine}{branch}{$iBranchIdx}{$iBranchPart} =
$stryData[3] eq '-' || $stryData[3] eq '0' ? false : true; $stryData[3] eq '-' || $stryData[3] eq '0' ? false : true;
if (!$rhCoverage->{$strFile}{line}{$strBranchLine}{branch}{$iBranchIdx}{$iBranchPart})
{
$rhCoverage->{$strFile}{line}{$strBranchLine}{branch}{covered} = false;
}
} }
# Check line coverage # Check line coverage
@ -457,52 +463,18 @@ sub coverageGenerate
} }
} }
# Remove branch coverage on lines that are completely covered # Remove file when no lines are uncovered
foreach my $strFile (sort(keys(%{$rhCoverage})))
{
foreach my $iLine (sort(keys(%{$rhCoverage->{$strFile}{line}})))
{
if (defined($rhCoverage->{$strFile}{line}{$iLine}{branch}))
{
# We'll assume the line is completely covered
my $bCovered = true;
foreach my $iBranch (sort(keys(%{$rhCoverage->{$strFile}{line}{$iLine}{branch}})))
{
foreach my $iBranchPart (sort(keys(%{$rhCoverage->{$strFile}{line}{$iLine}{branch}{$iBranch}})))
{
if (!$rhCoverage->{$strFile}{line}{$iLine}{branch}{$iBranch}{$iBranchPart})
{
$bCovered = false;
}
}
}
if ($bCovered)
{
# &log(WARN, "removed branch coverage for ${strFile} line ${iLine}");
if (defined($rhCoverage->{$strFile}{line}{$iLine}{statement}))
{
delete($rhCoverage->{$strFile}{line}{$iLine}{branch});
}
else
{
delete($rhCoverage->{$strFile}{line}{$iLine});
}
}
}
}
}
# Remove line when no lines are uncovered
foreach my $strFile (sort(keys(%{$rhCoverage}))) foreach my $strFile (sort(keys(%{$rhCoverage})))
{ {
my $bCovered = true; my $bCovered = true;
foreach my $iLine (sort(keys(%{$rhCoverage->{$strFile}{line}}))) foreach my $iLine (sort(keys(%{$rhCoverage->{$strFile}{line}})))
{ {
$bCovered = false; if (defined($rhCoverage->{$strFile}{line}{$iLine}{branch}) && !$rhCoverage->{$strFile}{line}{$iLine}{branch}{covered})
last; {
$bCovered = false;
last;
}
} }
if ($bCovered) if ($bCovered)
@ -791,42 +763,42 @@ sub coverageGenerate
my $strBranch; my $strBranch;
# Show missing branch coverage # Show missing branch coverage
if (defined($rhCoverage->{$strFile}{line}{$strLine}{branch}) && if (defined($rhCoverage->{$strFile}{line}{$strLine}{branch}))
!defined($rhCoverage->{$strFile}{line}{$strLine}{statement}))
{ {
my $iBranchIdx = 0;
foreach my $iBranch (sort(keys(%{$rhCoverage->{$strFile}{line}{$strLine}{branch}}))) foreach my $iBranch (sort(keys(%{$rhCoverage->{$strFile}{line}{$strLine}{branch}})))
{ {
$strBranch .= next if $iBranch eq 'covered';
'[' .
($rhCoverage->{$strFile}{line}{$strLine}{branch}{$iBranch}{0} ?
'+' : '-') .
' ' .
($rhCoverage->{$strFile}{line}{$strLine}{branch}{$iBranch}{1} ?
'+' : '-') .
']';
if ($iBranchIdx == 1) $strBranch .= '[';
my $bBranchPartFirst = true;
foreach my $iBranchPart (sort(keys(%{$rhCoverage->{$strFile}{line}{$strLine}{branch}{$iBranch}})))
{ {
$strBranch .= '<br/>'; if (!$bBranchPartFirst)
$iBranchIdx = 0; {
} $strBranch .= ' ';
else }
{
$strBranch .= ' '; $strBranch .= $rhCoverage->{$strFile}{line}{$strLine}{branch}{$iBranch}{$iBranchPart} ? '+' : '-';
$iBranchIdx++;
$bBranchPartFirst = false;
} }
$strBranch .= ']';
} }
} }
$oRow->addNew( $oRow->addNew(
HTML_TD, 'report-table-row-branch' . (defined($strBranch) ? '-uncovered' : ''), HTML_TD,
'report-table-row-branch' .
(defined($strBranch) && !$rhCoverage->{$strFile}{line}{$strLine}{branch}{covered} ? '-uncovered' : ''),
{strContent => $strBranch}); {strContent => $strBranch});
# Color code based on coverage # Color code based on coverage
my $bUncovered = my $bUncovered =
defined($rhCoverage->{$strFile}{line}{$strLine}{branch}) || (defined($rhCoverage->{$strFile}{line}{$strLine}{branch}) &&
!$rhCoverage->{$strFile}{line}{$strLine}{branch}{covered}) ||
defined($rhCoverage->{$strFile}{line}{$strLine}{statement}); defined($rhCoverage->{$strFile}{line}{$strLine}{statement});
$oRow->addNew( $oRow->addNew(