Private/Test-LookupResult.ps1
<# .SYNOPSIS Function to validate output when using -Name param instead of specifying Id, ensures a valid response and only one result returned. .DESCRIPTION The Test-LookupResult function is used to validate the output when using the -Name parameter instead of specifying the Id. It ensures that a valid response is received and only one result is returned. .PARAMETER Result The Result parameter represents the output of the lookup operation. .PARAMETER LookupString The LookupString parameter represents the value used for the lookup operation. .EXAMPLE Test-LookupResult -Result $result -LookupString "example" #> Function Test-LookupResult { Param ( $Result, $LookupString ) #If mutiple resources are returned stop processing If (($Result | Measure-Object).Count -gt 1) { [Console]::ForegroundColor = 'red' [Console]::Error.WriteLine("Mutiple resources returned for the specified name value: $LookupString. Please ensure value is unique and try again") [Console]::ResetColor() return $true } #If empty stop processing since we have no Id to use ElseIf (!$Result) { [Console]::ForegroundColor = 'red' [Console]::Error.WriteLine("Unable to find resource for the specified name value: $LookupString. Please check spelling and try again.") [Console]::ResetColor() return $true } return $false } |