diff --git a/src/functions/Coverage.ps1 b/src/functions/Coverage.ps1 index bc633e65f..bb9778699 100644 --- a/src/functions/Coverage.ps1 +++ b/src/functions/Coverage.ps1 @@ -452,6 +452,14 @@ function IsIgnoredCommand { return $true } + if ($PSVersionTable.PSVersion.Major -ge 5) { + if ($Command -is [System.Management.Automation.Language.CommandExpressionAst] -and + $Command.Expression[0] -is [System.Management.Automation.Language.BaseCtorInvokeMemberExpressionAst]) { + # Calls to inherited "base(...)" constructor does not trigger breakpoint or tracer hit, ignore. + return $true + } + } + return $false } diff --git a/tst/functions/Coverage.Tests.ps1 b/tst/functions/Coverage.Tests.ps1 index f9f5a9a16..6f328fdc1 100644 --- a/tst/functions/Coverage.Tests.ps1 +++ b/tst/functions/Coverage.Tests.ps1 @@ -52,9 +52,16 @@ InPesterModuleScope { if ($PSVersionTable.PSVersion.Major -ge 5) { Add-Content -Path $testScriptPath -Value @' - class MyClass + class MyBaseClass { + MyBaseClass() + { + 'I am the constructor of base class.' + } + } + + class MyClass : MyBaseClass { - MyClass() + MyClass() : base() { 'I am the constructor.' } @@ -79,11 +86,18 @@ InPesterModuleScope { # Before that, let's just create equivalent commands to above class with exact same line numbers Add-Content -Path $testScriptPath -Value @' + #class MyBaseClass { + function MyBaseClass + { + 'I am the constructor of base class.' + } + #} + #class MyClass #{ function MyClass { - 'I am the constructor.' + MyBaseClass; 'I am the constructor.' } function MethodOne @@ -131,7 +145,7 @@ InPesterModuleScope { # Path deliberately duplicated to make sure the code doesn't produce multiple breakpoints for the same commands $breakpoints = Enter-CoverageAnalysis -CodeCoverage $testScriptPath, $testScriptPath, $testScript2Path, $testScript3Path -UseBreakpoints $UseBreakpoints - @($breakpoints).Count | Should -Be 18 -Because 'it has the proper number of breakpoints defined' + @($breakpoints).Count | Should -Be 19 -Because 'it has the proper number of breakpoints defined' $sb = { $null = & $testScriptPath @@ -153,11 +167,11 @@ InPesterModuleScope { } It 'Reports the proper number of executed commands' { - $coverageReport.NumberOfCommandsExecuted | Should -Be 15 + $coverageReport.NumberOfCommandsExecuted | Should -Be 16 } It 'Reports the proper number of analyzed commands' { - $coverageReport.NumberOfCommandsAnalyzed | Should -Be 18 + $coverageReport.NumberOfCommandsAnalyzed | Should -Be 19 } It 'Reports the proper number of analyzed files' { @@ -175,7 +189,7 @@ InPesterModuleScope { } It 'Reports the proper number of hit commands' { - $coverageReport.HitCommands.Count | Should -Be 15 + $coverageReport.HitCommands.Count | Should -Be 16 } It 'Reports the correct hit command' { @@ -186,7 +200,8 @@ InPesterModuleScope { $coverageReport.HitCommands[0].Class | Should -BeNullOrEmpty # Classes have been introduced in PowerShell 5.0 if ($PSVersionTable.PSVersion.Major -ge 5) { - $coverageReport.HitCommands[9].Class | Should -Be 'MyClass' + $coverageReport.HitCommands[9].Class | Should -Be 'MyBaseClass' + $coverageReport.HitCommands[10].Class | Should -Be 'MyClass' $coverageReport.MissedCommands[2].Class | Should -Be 'MyClass' } else { @@ -198,7 +213,8 @@ InPesterModuleScope { It 'Reports the correct function names' { $coverageReport.HitCommands[0].Function | Should -Be 'NestedFunction' $coverageReport.HitCommands[2].Function | Should -Be 'FunctionOne' - $coverageReport.HitCommands[9].Function | Should -Be 'MyClass' + $coverageReport.HitCommands[9].Function | Should -Be 'MyBaseClass' + $coverageReport.HitCommands[10].Function | Should -Be 'MyClass' $coverageReport.MissedCommands[2].Function | Should -Be 'MethodTwo' } @@ -237,24 +253,29 @@ InPesterModuleScope { - + - + - + + + + + + - - - + + + @@ -278,14 +299,15 @@ InPesterModuleScope { - - - - - - - - + + + + + + + + + @@ -295,13 +317,14 @@ InPesterModuleScope { - - - + + + - + @@ -324,9 +347,9 @@ InPesterModuleScope { - - - + + + ') @@ -370,24 +393,29 @@ InPesterModuleScope { - + + + + + + - + - + - - - + + + @@ -411,14 +439,15 @@ InPesterModuleScope { - - - - - - - - + + + + + + + + + @@ -428,9 +457,9 @@ InPesterModuleScope { - - - + + + @@ -457,9 +486,9 @@ InPesterModuleScope { - - - + + + ') @@ -753,7 +782,7 @@ InPesterModuleScope { BeforeAll { $breakpoints = Enter-CoverageAnalysis -CodeCoverage @{Path = "$(Join-Path -Path $root -ChildPath *.ps1)"; Function = '*' } - @($breakpoints).Count | Should -Be 13 -Because 'it has the proper number of breakpoints defined' + @($breakpoints).Count | Should -Be 14 -Because 'it has the proper number of breakpoints defined' if ($UseBreakpoints) { & $testScriptPath @@ -768,11 +797,11 @@ InPesterModuleScope { } It 'Reports the proper number of executed commands' { - $coverageReport.NumberOfCommandsExecuted | Should -Be 10 + $coverageReport.NumberOfCommandsExecuted | Should -Be 11 } It 'Reports the proper number of analyzed commands' { - $coverageReport.NumberOfCommandsAnalyzed | Should -Be 13 + $coverageReport.NumberOfCommandsAnalyzed | Should -Be 14 } It 'Reports the proper number of analyzed files' { @@ -789,7 +818,7 @@ InPesterModuleScope { } It 'Reports the proper number of hit commands' { - $coverageReport.HitCommands.Count | Should -Be 10 + $coverageReport.HitCommands.Count | Should -Be 11 } It 'Reports the correct hit command' { @@ -858,7 +887,7 @@ InPesterModuleScope { $breakpoints = Enter-CoverageAnalysis -CodeCoverage @{Path = $testScriptPath; Class = '*' } - @($breakpoints).Count | Should -Be 3 -Because 'it has the proper number of breakpoints defined' + @($breakpoints).Count | Should -Be 4 -Because 'it has the proper number of breakpoints defined' if ($UseBreakpoints) { & $testScriptPath @@ -873,11 +902,11 @@ InPesterModuleScope { } It 'Reports the proper number of executed commands' { - $coverageReport.NumberOfCommandsExecuted | Should -Be 2 + $coverageReport.NumberOfCommandsExecuted | Should -Be 3 } It 'Reports the proper number of analyzed commands' { - $coverageReport.NumberOfCommandsAnalyzed | Should -Be 3 + $coverageReport.NumberOfCommandsAnalyzed | Should -Be 4 } It 'Reports the proper number of missed commands' { @@ -885,7 +914,7 @@ InPesterModuleScope { } It 'Reports the proper number of hit commands' { - $coverageReport.HitCommands.Count | Should -Be 2 + $coverageReport.HitCommands.Count | Should -Be 3 } AfterAll {