From e6b2c8ccad5b35a11df601cde0b8dfb096a080b9 Mon Sep 17 00:00:00 2001 From: Frode Flaten <3436158+fflaten@users.noreply.github.com> Date: Mon, 1 Jul 2024 18:18:09 +0200 Subject: [PATCH] Add OutputType to improve tab-completion/intellisense (#2519) * Add OutputType to public functions for tab completion * Add OutputType to a few internal methods --- src/Main.ps1 | 1 + src/Pester.RSpec.ps1 | 2 ++ src/Pester.Runtime.ps1 | 6 ++++-- src/functions/New-Fixture.ps1 | 6 ++++-- src/functions/TestResults.ps1 | 6 ++++-- 5 files changed, 15 insertions(+), 6 deletions(-) diff --git a/src/Main.ps1 b/src/Main.ps1 index 4c00b301f..953e04fce 100644 --- a/src/Main.ps1 +++ b/src/Main.ps1 @@ -562,6 +562,7 @@ function Invoke-Pester { # Currently doesn't work. $IgnoreUnsafeCommands filter used in rule as workaround # [Diagnostics.CodeAnalysis.SuppressMessageAttribute('Pester.BuildAnalyzerRules\Measure-SafeCommands', 'Remove-Variable', Justification = 'Remove-Variable can't remove "optimized variables" when using "alias" for Remove-Variable.')] [CmdletBinding(DefaultParameterSetName = 'Simple')] + [OutputType([Pester.Run])] param( [Parameter(Position = 0, Mandatory = 0, ParameterSetName = "Simple")] [Parameter(Position = 0, Mandatory = 0, ParameterSetName = "Legacy")] # Legacy set for v4 compatibility during migration - deprecated diff --git a/src/Pester.RSpec.ps1 b/src/Pester.RSpec.ps1 index 9f043ea04..8e42aa229 100644 --- a/src/Pester.RSpec.ps1 +++ b/src/Pester.RSpec.ps1 @@ -341,6 +341,7 @@ function New-PesterConfiguration { about_PesterConfiguration #> [CmdletBinding()] + [OutputType([PesterConfiguration])] param( [System.Collections.IDictionary] $Hashtable ) @@ -543,6 +544,7 @@ function New-PesterContainer { https://pester.dev/docs/usage/data-driven-tests #> [CmdletBinding(DefaultParameterSetName = "Path")] + [OutputType([Pester.ContainerInfo])] param( [Parameter(Mandatory, ParameterSetName = "Path")] [String[]] $Path, diff --git a/src/Pester.Runtime.ps1 b/src/Pester.Runtime.ps1 index 8ed98e58c..075fc89af 100644 --- a/src/Pester.Runtime.ps1 +++ b/src/Pester.Runtime.ps1 @@ -110,6 +110,7 @@ function Reset-PerContainerState { } function Find-Test { + [OutputType([Pester.Container])] [CmdletBinding()] param ( [Parameter(Mandatory = $true)] @@ -138,6 +139,7 @@ function Find-Test { } function ConvertTo-DiscoveredBlockContainer { + [OutputType([Pester.Container])] param ( [Parameter(Mandatory = $true)] $Block @@ -148,6 +150,7 @@ function ConvertTo-DiscoveredBlockContainer { } function ConvertTo-ExecutedBlockContainer { + [OutputType([Pester.Container])] param ( [Parameter(Mandatory = $true)] $Block @@ -156,8 +159,6 @@ function ConvertTo-ExecutedBlockContainer { foreach ($b in $Block) { [Pester.Container]::CreateFromBlock($b) } - - } function New-ParametrizedBlock { @@ -2479,6 +2480,7 @@ function Invoke-BlockContainer { } function New-BlockContainerObject { + [OutputType([Pester.ContainerInfo])] [CmdletBinding()] param ( [Parameter(Mandatory, ParameterSetName = 'ScriptBlock')] diff --git a/src/functions/New-Fixture.ps1 b/src/functions/New-Fixture.ps1 index 2a5ec42cc..ca7bfeab1 100644 --- a/src/functions/New-Fixture.ps1 +++ b/src/functions/New-Fixture.ps1 @@ -69,6 +69,7 @@ .LINK https://pester.dev/docs/commands/Should #> + [OutputType([System.IO.FileInfo])] param ( [Parameter(Mandatory = $true)] [String]$Name, @@ -78,7 +79,7 @@ $Name = $Name -replace '.ps(m?)1', '' if ($Name -notmatch '^\S+$') { - throw "Name is not valid. Whitespace are not allowed in a function name." + throw 'Name is not valid. Whitespace are not allowed in a function name.' } #keep this formatted as is. the format is output to the file as is, including indentation @@ -94,7 +95,7 @@ Describe "#name#" { It "Returns expected output" { #name# | Should -Be "YOUR_EXPECTED_VALUE" } -}' -replace "#name#", $Name +}' -replace '#name#', $Name $Path = $ExecutionContext.SessionState.Path.GetUnresolvedProviderPathFromPSPath($Path) @@ -104,6 +105,7 @@ Describe "#name#" { function Create-File { [Diagnostics.CodeAnalysis.SuppressMessageAttribute('Pester.BuildAnalyzerRules\Measure-SafeCommands', 'Write-Warning', Justification = 'Mocked in unit test for New-Fixture.')] + [OutputType([System.IO.FileInfo])] param($Path, $Name, $Content) if (-not (& $SafeCommands['Test-Path'] -Path $Path)) { & $SafeCommands['New-Item'] -ItemType Directory -Path $Path | & $SafeCommands['Out-Null'] diff --git a/src/functions/TestResults.ps1 b/src/functions/TestResults.ps1 index ba7494072..dd3404d0d 100644 --- a/src/functions/TestResults.ps1 +++ b/src/functions/TestResults.ps1 @@ -270,8 +270,9 @@ function ConvertTo-NUnitReport { .LINK https://pester.dev/docs/commands/Invoke-Pester #> + [OutputType([xml], [string])] param ( - [parameter(Mandatory = $true, ValueFromPipeline = $true)] + [Parameter(Mandatory = $true, ValueFromPipeline = $true)] [Pester.Run] $Result, [Switch] $AsString, @@ -360,8 +361,9 @@ function ConvertTo-JUnitReport { .LINK https://pester.dev/docs/commands/Invoke-Pester #> + [OutputType([xml], [string])] param ( - [parameter(Mandatory = $true, ValueFromPipeline = $true)] + [Parameter(Mandatory = $true, ValueFromPipeline = $true)] [Pester.Run] $Result, [Switch] $AsString )