From 30a51c528735f265b36dfb6157847d41be5d8033 Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Mon, 22 Jan 2024 21:05:41 +0100 Subject: [PATCH 1/7] Add PassThru parameter to error record creation functions --- CHANGELOG.md | 25 +++++ ...xception.ps1 => New-ArgumentException.ps1} | 35 +++++-- source/Public/New-Exception.ps1 | 68 +++++++++++++ source/Public/New-InvalidDataException.ps1 | 13 ++- .../Public/New-InvalidOperationException.ps1 | 34 +++++-- source/Public/New-NotImplementedException.ps1 | 33 +++++-- source/Public/New-ObjectNotFoundException.ps1 | 2 +- source/WikiSource/Home.md | 2 - .../Public/New-ArgumentException.Tests.ps1 | 98 +++++++++++++++++++ ...tion.Tests.ps1 => New-Exception.Tests.ps1} | 34 +++++-- .../New-InvalidOperationException.Tests.ps1 | 27 +++++ .../New-NotImplementedException.Tests.ps1 | 17 ++++ 12 files changed, 351 insertions(+), 37 deletions(-) rename source/Public/{New-InvalidArgumentException.ps1 => New-ArgumentException.ps1} (54%) create mode 100644 source/Public/New-Exception.ps1 create mode 100644 tests/Unit/Public/New-ArgumentException.Tests.ps1 rename tests/Unit/Public/{New-InvalidArgumentException.Tests.ps1 => New-Exception.Tests.ps1} (60%) diff --git a/CHANGELOG.md b/CHANGELOG.md index e58db14..7dca8a0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -15,6 +15,20 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 that can copy from omne target to the other ([issue #102](https://github.com/dsccommunity/DscResource.Common/issues/102)). - A new parameter `PassThru` that, if specified, returns the path that was set. +- `New-Exception` + - New command that creates and returns an `[System.Exception]`. +- `New-ArgumentException` + - Now takes a parameter `PassThru` that returns the error record that was + created (and does not throw). +- `New-InvalidOperationException` + - Now takes a parameter `PassThru` that returns the error record that was + created (and does not throw) ([issue #98](https://github.com/dsccommunity/DscResource.Common/issues/98)). +- `New-InvalidResultException` + - Now takes a parameter `PassThru` that returns the error record that was + created (and does not throw). +- `New-NotImplementedException` + - Now takes a parameter `PassThru` that returns the error record that was + created (and does not throw). ### Changed @@ -23,6 +37,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Change the word cmdlet to command throughout in the documentation, code and localization strings. - A meta task now removes the built module from the session if it is imported. +- Wiki source file HOME was modified to not link to README for help after + command documentation now is in the wiki. - `Get-LocalizedData` - Refactored to simplify execution and debugging. The command previously used a steppable pipeline (proxies `Import-LocalizedData`), that was @@ -30,6 +46,13 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 It just made it more complex and harder to debug. There are more debug messages added to hopefully simplify solving some hard to find edge cases bugs. +- `New-ArgumentException` + - Now has a command alias `New-InvalidArgumentException` and the command + was renamed to match the exception name. +- `New-InvalidDataException` + - The parameter `Message` has a parameter alias `ErrorMessage` to make + the command have the same parameter names as the other `New-*Exception` + commands. ### Fixed @@ -37,6 +60,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Fixed example in documentation that were referencing an invalid command name. - `Get-LocalizedData` - One debug message was wrongly using a format operator ([issue #111](https://github.com/dsccommunity/DscResource.Common/issues/111). +- `New-ObjectNotFoundException` + - Updated typo in comment-based help. ## [0.16.0] - 2023-04-10 diff --git a/source/Public/New-InvalidArgumentException.ps1 b/source/Public/New-ArgumentException.ps1 similarity index 54% rename from source/Public/New-InvalidArgumentException.ps1 rename to source/Public/New-ArgumentException.ps1 index 75d507e..300f8d9 100644 --- a/source/Public/New-InvalidArgumentException.ps1 +++ b/source/Public/New-ArgumentException.ps1 @@ -1,9 +1,9 @@ <# .SYNOPSIS - Creates and throws an invalid argument exception. + Creates and throws or returns an invalid argument exception. .DESCRIPTION - Creates and throws an invalid argument exception. + Creates and throws or returns an invalid argument exception. .PARAMETER Message The message explaining why this error is being thrown. @@ -11,19 +11,31 @@ .PARAMETER ArgumentName The name of the invalid argument that is causing this error to be thrown. + .PARAMETER PassThru + If specified, returns the error record instead of throwing it. + .OUTPUTS None + System.Management.Automation.ErrorRecord .EXAMPLE - New-InvalidArgumentException -ArgumentName 'Action' -Message 'My error message' + New-ArgumentException -ArgumentName 'Action' -Message 'My error message' Creates and throws an invalid argument exception for (parameter) 'Action' with the message 'My error message'. + + .EXAMPLE + $errorRecord = New-ArgumentException -ArgumentName 'Action' -Message 'My error message' -PassThru + + Creates an invalid argument exception for (parameter) 'Action' + with the message 'My error message' and returns the exception. #> -function New-InvalidArgumentException + +function New-ArgumentException { [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')] [CmdletBinding()] + [Alias('New-InvalidArgumentException')] param ( [Parameter(Mandatory = $true)] @@ -34,7 +46,11 @@ function New-InvalidArgumentException [Parameter(Mandatory = $true)] [ValidateNotNullOrEmpty()] [System.String] - $ArgumentName + $ArgumentName, + + [Parameter()] + [System.Management.Automation.SwitchParameter] + $PassThru ) $argumentException = New-Object -TypeName 'ArgumentException' ` @@ -47,5 +63,12 @@ function New-InvalidArgumentException $errorRecord = New-Object @newObjectParameters - throw $errorRecord + if ($PassThru.IsPresent) + { + return $argumentException + } + else + { + throw $errorRecord + } } diff --git a/source/Public/New-Exception.ps1 b/source/Public/New-Exception.ps1 new file mode 100644 index 0000000..88439d7 --- /dev/null +++ b/source/Public/New-Exception.ps1 @@ -0,0 +1,68 @@ +<# + .SYNOPSIS + Creates and returns an exception. + + .DESCRIPTION + Creates and returns an exception. + + .OUTPUTS + None + + .PARAMETER Message + The message explaining why this error is being thrown. + + .PARAMETER ErrorRecord + The error record containing the exception that is causing this terminating error. + + .OUTPUTS + System.Management.Automation.ErrorRecord + + .EXAMPLE + $errorRecord = New-Exception -Message 'An error occurred' + + Creates and returns an exception with the message 'An error occurred'. + + .EXAMPLE + try + { + Get-ChildItem -Path $path -ErrorAction 'Stop' + } + catch + { + $exception = New-Exception -Message 'Could not get files' -ErrorRecord $_ + } + + Returns an exception with the message 'Could not get files' and includes + the exception that caused this terminating error. + +#> +function New-Exception +{ + [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')] + [CmdletBinding()] + param + ( + [Parameter(Mandatory = $true)] + [ValidateNotNullOrEmpty()] + [System.String] + $Message, + + [Parameter()] + [ValidateNotNull()] + [System.Management.Automation.ErrorRecord] + $ErrorRecord + ) + + if ($null -eq $ErrorRecord) + { + $exception = New-Object -TypeName 'System.Exception' ` + -ArgumentList @($Message) + } + else + { + $exception = New-Object -TypeName 'System.Exception' ` + -ArgumentList @($Message, $ErrorRecord.Exception) + } + + return $exception +} diff --git a/source/Public/New-InvalidDataException.ps1 b/source/Public/New-InvalidDataException.ps1 index 35e31d5..fcf3431 100644 --- a/source/Public/New-InvalidDataException.ps1 +++ b/source/Public/New-InvalidDataException.ps1 @@ -15,7 +15,7 @@ The error message to assign to the exception. .EXAMPLE - New-InvalidDataException -ErrorId 'InvalidDataError' -ErrorMessage 'My error message' + New-InvalidDataException -ErrorId 'InvalidDataError' -Message 'My error message' Creates and throws an invalid data exception with the error id 'InvalidDataError' and with the message 'My error message'. @@ -31,16 +31,19 @@ function New-InvalidDataException $ErrorId, [Parameter(Mandatory = $true)] + [Alias('ErrorMessage')] [System.String] - $ErrorMessage + $Message ) $errorCategory = [System.Management.Automation.ErrorCategory]::InvalidData + $exception = New-Object ` - -TypeName System.InvalidOperationException ` - -ArgumentList $ErrorMessage + -TypeName 'System.InvalidOperationException' ` + -ArgumentList $Message + $errorRecord = New-Object ` - -TypeName System.Management.Automation.ErrorRecord ` + -TypeName 'System.Management.Automation.ErrorRecord' ` -ArgumentList $exception, $ErrorId, $errorCategory, $null throw $errorRecord diff --git a/source/Public/New-InvalidOperationException.ps1 b/source/Public/New-InvalidOperationException.ps1 index 90ba5f8..56aeae9 100644 --- a/source/Public/New-InvalidOperationException.ps1 +++ b/source/Public/New-InvalidOperationException.ps1 @@ -1,12 +1,13 @@ <# .SYNOPSIS - Creates and throws an invalid operation exception. + Creates and throws or returns an invalid operation exception. .DESCRIPTION - Creates and throws an invalid operation exception. + Creates and throws or returns an invalid operation exception. .OUTPUTS - None + None. If the PassThru parameter is not specified the command throws an error record. + System.Management.Automation.ErrorRecord. If the PassThru parameter is specified the command returns an error record. .PARAMETER Message The message explaining why this error is being thrown. @@ -14,6 +15,9 @@ .PARAMETER ErrorRecord The error record containing the exception that is causing this terminating error. + .PARAMETER PassThru + If specified, returns the error record instead of throwing it. + .EXAMPLE try { @@ -26,7 +30,12 @@ Creates and throws an invalid operation exception with the message 'My error message' and includes the exception that caused this terminating error. -#> + + .EXAMPLE + $errorRecord = New-InvalidOperationException -Message 'My error message' -PassThru + + Creates and returns an invalid operation exception with the message 'My error message'. + #> function New-InvalidOperationException { [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')] @@ -41,7 +50,11 @@ function New-InvalidOperationException [Parameter()] [ValidateNotNull()] [System.Management.Automation.ErrorRecord] - $ErrorRecord + $ErrorRecord, + + [Parameter()] + [System.Management.Automation.SwitchParameter] + $PassThru ) if ($null -eq $ErrorRecord) @@ -65,7 +78,14 @@ function New-InvalidOperationException ) } - $errorRecordToThrow = New-Object @newObjectParameters + $errorRecordToReturn = New-Object @newObjectParameters - throw $errorRecordToThrow + if ($PassThru.IsPresent) + { + return $invalidOperationException + } + else + { + throw $errorRecordToReturn + } } diff --git a/source/Public/New-NotImplementedException.ps1 b/source/Public/New-NotImplementedException.ps1 index 855819c..d501f82 100644 --- a/source/Public/New-NotImplementedException.ps1 +++ b/source/Public/New-NotImplementedException.ps1 @@ -1,9 +1,9 @@ <# .SYNOPSIS - Creates and throws an not implemented exception. + Creates and throws or returns an not implemented exception. .DESCRIPTION - Creates and throws an not implemented exception. + Creates and throws or returns an not implemented exception. .PARAMETER Message The message explaining why this error is being thrown. @@ -11,8 +11,12 @@ .PARAMETER ErrorRecord The error record containing the exception that is causing this terminating error. + .PARAMETER PassThru + If specified, returns the error record instead of throwing it. + .OUTPUTS None + System.Management.Automation.ErrorRecord .EXAMPLE if ($notImplementedFeature) @@ -21,7 +25,13 @@ } Creates and throws an not implemented exception with the message 'This feature - is not implemented yet' + is not implemented yet'. + + .EXAMPLE + $errorRecord = New-NotImplementedException -Message 'This feature is not implemented yet' -PassThru + + Creates and returns an not implemented exception with the message 'This feature + is not implemented yet'. #> function New-NotImplementedException { @@ -37,7 +47,11 @@ function New-NotImplementedException [Parameter()] [ValidateNotNull()] [System.Management.Automation.ErrorRecord] - $ErrorRecord + $ErrorRecord, + + [Parameter()] + [System.Management.Automation.SwitchParameter] + $PassThru ) if ($null -eq $ErrorRecord) @@ -61,7 +75,14 @@ function New-NotImplementedException ) } - $errorRecordToThrow = New-Object @newObjectParameters + $errorRecord = New-Object @newObjectParameters - throw $errorRecordToThrow + if ($PassThru.IsPresent) + { + return $invalidOperationException + } + else + { + throw $errorRecord + } } diff --git a/source/Public/New-ObjectNotFoundException.ps1 b/source/Public/New-ObjectNotFoundException.ps1 index 2eec32c..59004de 100644 --- a/source/Public/New-ObjectNotFoundException.ps1 +++ b/source/Public/New-ObjectNotFoundException.ps1 @@ -24,7 +24,7 @@ } catch { - New-ObjectNotFoundException -Message 'COuld not get files' -ErrorRecord $_ + New-ObjectNotFoundException -Message 'Could not get files' -ErrorRecord $_ } Creates and throws an object not found exception with the message 'Could not diff --git a/source/WikiSource/Home.md b/source/WikiSource/Home.md index ee50fe0..30b3184 100644 --- a/source/WikiSource/Home.md +++ b/source/WikiSource/Home.md @@ -2,8 +2,6 @@ *DscResource.Common v#.#.#* -For documentation please see the [README.md](https://github.com/dsccommunity/DscResource.Common/blob/main/README.md) - Please leave comments, feature requests, and bug reports for this module in the [issues section](https://github.com/dsccommunity/DscResource.Common/issues) for this repository. diff --git a/tests/Unit/Public/New-ArgumentException.Tests.ps1 b/tests/Unit/Public/New-ArgumentException.Tests.ps1 new file mode 100644 index 0000000..c7fa236 --- /dev/null +++ b/tests/Unit/Public/New-ArgumentException.Tests.ps1 @@ -0,0 +1,98 @@ +[System.Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseDeclaredVarsMoreThanAssignments', '')] +param () + +BeforeDiscovery { + try + { + if (-not (Get-Module -Name 'DscResource.Test')) + { + # Assumes dependencies has been resolved, so if this module is not available, run 'noop' task. + if (-not (Get-Module -Name 'DscResource.Test' -ListAvailable)) + { + # Redirect all streams to $null, except the error stream (stream 2) + & "$PSScriptRoot/../../build.ps1" -Tasks 'noop' 2>&1 4>&1 5>&1 6>&1 > $null + } + + # If the dependencies has not been resolved, this will throw an error. + Import-Module -Name 'DscResource.Test' -Force -ErrorAction 'Stop' + } + } + catch [System.IO.FileNotFoundException] + { + throw 'DscResource.Test module dependency not found. Please run ".\build.ps1 -ResolveDependency -Tasks build" first.' + } +} + +BeforeAll { + $script:moduleName = 'DscResource.Common' + + # Make sure there are not other modules imported that will conflict with mocks. + Get-Module -Name $script:moduleName -All | Remove-Module -Force + + # Re-import the module using force to get any code changes between runs. + Import-Module -Name $script:moduleName -Force -ErrorAction 'Stop' + + $PSDefaultParameterValues['InModuleScope:ModuleName'] = $script:moduleName + $PSDefaultParameterValues['Mock:ModuleName'] = $script:moduleName + $PSDefaultParameterValues['Should:ModuleName'] = $script:moduleName +} + +AfterAll { + $PSDefaultParameterValues.Remove('Mock:ModuleName') + $PSDefaultParameterValues.Remove('InModuleScope:ModuleName') + $PSDefaultParameterValues.Remove('Should:ModuleName') + + Remove-Module -Name $script:moduleName +} + +Describe 'New-ArgumentException' { + Context 'When calling with both the Message and ArgumentName parameter' { + It 'Should throw the correct error' { + $mockErrorMessage = 'Mocked error' + $mockArgumentName = 'MockArgument' + + # Wildcard processing needed to handle differing Powershell 5/6/7 exception output + { New-ArgumentException -Message $mockErrorMessage -ArgumentName $mockArgumentName } | + Should -Throw -PassThru | Select-Object -ExpandProperty Exception | + Should -BeLike ('{0}*Parameter*{1}*' -f $mockErrorMesssage, $mockArgumentName) + } + } + + Context 'When using command alias New-InvalidArgumentException' { + It 'Should throw the correct error' { + $mockErrorMessage = 'Mocked error' + $mockArgumentName = 'MockArgument' + + # Wildcard processing needed to handle differing Powershell 5/6/7 exception output + { New-InvalidArgumentException -Message $mockErrorMessage -ArgumentName $mockArgumentName } | + Should -Throw -PassThru | Select-Object -ExpandProperty Exception | + Should -BeLike ('{0}*Parameter*{1}*' -f $mockErrorMesssage, $mockArgumentName) + } + } + + Context 'When calling with the PassThru parameter' { + It 'Should return the correct error record' { + $mockErrorMessage = 'Mocked error' + $mockArgumentName = 'MockArgument' + + $result = New-ArgumentException -Message $mockErrorMessage -ArgumentName $mockArgumentName -PassThru + $result | Should -BeOfType 'System.ArgumentException' + $result.Message | Should -Be ("{0} (Parameter '{1}')" -f $mockErrorMessage, $mockArgumentName) + $result.ParamName | Should -Be $mockArgumentName + } + } + + Context 'When calling without the PassThru parameter' { + It 'Should throw the correct error' { + $mockErrorMessage = 'Mocked error' + $mockArgumentName = 'MockArgument' + + $result = { New-ArgumentException -Message $mockErrorMessage -ArgumentName $mockArgumentName } | + Should -Throw -PassThru + + $result | Should -BeOfType 'System.Management.Automation.ErrorRecord' + $result | Select-Object -ExpandProperty 'Exception' | + Should -BeLike ('System.ArgumentException: {0}*Parameter*{1}*' -f $mockErrorMessage, $mockArgumentName) + } + } +} diff --git a/tests/Unit/Public/New-InvalidArgumentException.Tests.ps1 b/tests/Unit/Public/New-Exception.Tests.ps1 similarity index 60% rename from tests/Unit/Public/New-InvalidArgumentException.Tests.ps1 rename to tests/Unit/Public/New-Exception.Tests.ps1 index 55d6451..d9fe35f 100644 --- a/tests/Unit/Public/New-InvalidArgumentException.Tests.ps1 +++ b/tests/Unit/Public/New-Exception.Tests.ps1 @@ -45,16 +45,30 @@ AfterAll { Remove-Module -Name $script:moduleName } -Describe 'New-InvalidArgumentException' { - Context 'When calling with both the Message and ArgumentName parameter' { - It 'Should throw the correct error' { - $mockErrorMessage = 'Mocked error' - $mockArgumentName = 'MockArgument' - - # Wildcard processing needed to handle differing Powershell 5/6/7 exception output - { New-InvalidArgumentException -Message $mockErrorMessage -ArgumentName $mockArgumentName } | - Should -Throw -PassThru | Select-Object -ExpandProperty Exception | - Should -BeLike ('{0}*Parameter*{1}*' -f $mockErrorMesssage, $mockArgumentName) +Describe 'New-Exception' { + Context 'When calling with Message parameter only' { + It 'Should return the correct exception' { + $mockMessage = 'Test exception message' + $result = New-Exception -Message $mockMessage + $result | Should -BeOfType System.Exception + $result.Message | Should -Be $mockMessage + } + } + + Context 'When calling with both the Message and ErrorRecord parameter' { + It 'Should return the correct exception' { + $mockMessage = 'Test exception message' + $mockInnerExceptionMessage = 'Test inner exception message' + + $mockInnerException = New-Object -TypeName System.Exception -ArgumentList $mockInnerExceptionMessage + $mockErrorRecord = New-Object -TypeName System.Management.Automation.ErrorRecord ` + -ArgumentList $mockInnerException, $null, 'NotSpecified', $null + + $result = New-Exception -Message $mockMessage -ErrorRecord $mockErrorRecord + + $result | Should -BeOfType System.Exception + $result.Message | Should -Be $mockMessage + $result.InnerException.Message | Should -Be $mockInnerExceptionMessage } } } diff --git a/tests/Unit/Public/New-InvalidOperationException.Tests.ps1 b/tests/Unit/Public/New-InvalidOperationException.Tests.ps1 index 100453c..6344cc7 100644 --- a/tests/Unit/Public/New-InvalidOperationException.Tests.ps1 +++ b/tests/Unit/Public/New-InvalidOperationException.Tests.ps1 @@ -71,4 +71,31 @@ Describe 'New-InvalidOperationException' { $mockErrorMessage, $mockExceptionErrorMessage) } } + + Context 'When calling with Message and PassThru parameters' { + It 'Should return the correct error record' { + $mockErrorMessage = 'Mocked error' + + $result = New-InvalidOperationException -Message $mockErrorMessage -PassThru + + $result | Should -BeOfType 'System.InvalidOperationException' + $result.Message | Should -Be $mockErrorMessage + } + } + + Context 'When calling with Message, ErrorRecord and PassThru parameters' { + It 'Should return the correct error record' { + $mockErrorMessage = 'Mocked error' + $mockExceptionErrorMessage = 'Mocked exception error message' + + $mockException = New-Object -TypeName 'System.Exception' -ArgumentList $mockExceptionErrorMessage + $mockErrorRecord = New-Object -TypeName 'System.Management.Automation.ErrorRecord' ` + -ArgumentList $mockException, $null, 'InvalidResult', $null + + $result = New-InvalidOperationException -Message $mockErrorMessage -ErrorRecord $mockErrorRecord -PassThru + + $result | Should -BeOfType 'System.InvalidOperationException' + $result.Message | Should -Be $mockErrorMessage + } + } } diff --git a/tests/Unit/Public/New-NotImplementedException.Tests.ps1 b/tests/Unit/Public/New-NotImplementedException.Tests.ps1 index 57fdf15..74aae44 100644 --- a/tests/Unit/Public/New-NotImplementedException.Tests.ps1 +++ b/tests/Unit/Public/New-NotImplementedException.Tests.ps1 @@ -71,4 +71,21 @@ Describe 'New-NotImplementedException' { $mockErrorMessage, $mockExceptionErrorMessage) } } + + Context 'When called with PassThru parameter' { + It 'Should return the correct error record' { + $mockErrorMessage = 'Mocked error' + $mockExceptionErrorMessage = 'Mocked exception error message' + + $mockException = New-Object -TypeName System.Exception -ArgumentList $mockExceptionErrorMessage + $mockErrorRecord = New-Object -TypeName System.Management.Automation.ErrorRecord ` + -ArgumentList $mockException, $null, 'InvalidResult', $null + + $result = New-NotImplementedException -Message $mockErrorMessage -ErrorRecord $mockErrorRecord -PassThru + + $result | Should -BeOfType System.NotImplementedException + $result.Message | Should -Be $mockErrorMessage + } + } + } From d475b3d2be9e6983b00c2aeeee7b67762d3e08e3 Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Mon, 22 Jan 2024 21:18:00 +0100 Subject: [PATCH 2/7] Fix review comment at r1 --- source/Public/New-InvalidResultException.ps1 | 11 +---------- source/Public/New-ObjectNotFoundException.ps1 | 11 +---------- 2 files changed, 2 insertions(+), 20 deletions(-) diff --git a/source/Public/New-InvalidResultException.ps1 b/source/Public/New-InvalidResultException.ps1 index 3dec5ed..9332a3e 100644 --- a/source/Public/New-InvalidResultException.ps1 +++ b/source/Public/New-InvalidResultException.ps1 @@ -53,16 +53,7 @@ function New-InvalidResultException $ErrorRecord ) - if ($null -eq $ErrorRecord) - { - $exception = New-Object -TypeName 'System.Exception' ` - -ArgumentList @($Message) - } - else - { - $exception = New-Object -TypeName 'System.Exception' ` - -ArgumentList @($Message, $ErrorRecord.Exception) - } + $exception = New-Exception @PSBoundParameters $newObjectParameters = @{ TypeName = 'System.Management.Automation.ErrorRecord' diff --git a/source/Public/New-ObjectNotFoundException.ps1 b/source/Public/New-ObjectNotFoundException.ps1 index 59004de..c593f1a 100644 --- a/source/Public/New-ObjectNotFoundException.ps1 +++ b/source/Public/New-ObjectNotFoundException.ps1 @@ -47,16 +47,7 @@ function New-ObjectNotFoundException $ErrorRecord ) - if ($null -eq $ErrorRecord) - { - $exception = New-Object -TypeName 'System.Exception' ` - -ArgumentList @($Message) - } - else - { - $exception = New-Object -TypeName 'System.Exception' ` - -ArgumentList @($Message, $ErrorRecord.Exception) - } + $exception = New-Exception @PSBoundParameters $newObjectParameters = @{ TypeName = 'System.Management.Automation.ErrorRecord' From e93d4788ae4848c0642ae966ba2d2588aeb9d613 Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Tue, 23 Jan 2024 07:51:27 +0100 Subject: [PATCH 3/7] Fix output type --- source/Public/New-Exception.ps1 | 3 ++- source/Public/New-InvalidOperationException.ps1 | 7 ++++--- source/Public/New-NotImplementedException.ps1 | 9 +++++---- 3 files changed, 11 insertions(+), 8 deletions(-) diff --git a/source/Public/New-Exception.ps1 b/source/Public/New-Exception.ps1 index 88439d7..a364e3d 100644 --- a/source/Public/New-Exception.ps1 +++ b/source/Public/New-Exception.ps1 @@ -15,7 +15,7 @@ The error record containing the exception that is causing this terminating error. .OUTPUTS - System.Management.Automation.ErrorRecord + System.Exception .EXAMPLE $errorRecord = New-Exception -Message 'An error occurred' @@ -40,6 +40,7 @@ function New-Exception { [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')] [CmdletBinding()] + [OutputType([System.Exception])] param ( [Parameter(Mandatory = $true)] diff --git a/source/Public/New-InvalidOperationException.ps1 b/source/Public/New-InvalidOperationException.ps1 index 56aeae9..28f4ce5 100644 --- a/source/Public/New-InvalidOperationException.ps1 +++ b/source/Public/New-InvalidOperationException.ps1 @@ -7,7 +7,7 @@ .OUTPUTS None. If the PassThru parameter is not specified the command throws an error record. - System.Management.Automation.ErrorRecord. If the PassThru parameter is specified the command returns an error record. + System.InvalidOperationException. If the PassThru parameter is specified the command returns an error record. .PARAMETER Message The message explaining why this error is being thrown. @@ -40,6 +40,7 @@ function New-InvalidOperationException { [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')] [CmdletBinding()] + [OutputType([System.InvalidOperationException])] param ( [Parameter(Mandatory = $true)] @@ -59,12 +60,12 @@ function New-InvalidOperationException if ($null -eq $ErrorRecord) { - $invalidOperationException = New-Object -TypeName 'InvalidOperationException' ` + $invalidOperationException = New-Object -TypeName 'System.InvalidOperationException' ` -ArgumentList @($Message) } else { - $invalidOperationException = New-Object -TypeName 'InvalidOperationException' ` + $invalidOperationException = New-Object -TypeName 'System.InvalidOperationException' ` -ArgumentList @($Message, $ErrorRecord.Exception) } diff --git a/source/Public/New-NotImplementedException.ps1 b/source/Public/New-NotImplementedException.ps1 index d501f82..d42cd70 100644 --- a/source/Public/New-NotImplementedException.ps1 +++ b/source/Public/New-NotImplementedException.ps1 @@ -16,7 +16,7 @@ .OUTPUTS None - System.Management.Automation.ErrorRecord + System.NotImplementedException .EXAMPLE if ($notImplementedFeature) @@ -37,6 +37,7 @@ function New-NotImplementedException { [Diagnostics.CodeAnalysis.SuppressMessageAttribute('PSUseShouldProcessForStateChangingFunctions', '')] [CmdletBinding()] + [OutputType([System.NotImplementedException])] param ( [Parameter(Mandatory = $true)] @@ -56,19 +57,19 @@ function New-NotImplementedException if ($null -eq $ErrorRecord) { - $invalidOperationException = New-Object -TypeName 'NotImplementedException' ` + $notImplementedException = New-Object -TypeName 'System.NotImplementedException' ` -ArgumentList @($Message) } else { - $invalidOperationException = New-Object -TypeName 'NotImplementedException' ` + $notImplementedException = New-Object -TypeName 'System.NotImplementedException' ` -ArgumentList @($Message, $ErrorRecord.Exception) } $newObjectParameters = @{ TypeName = 'System.Management.Automation.ErrorRecord' ArgumentList = @( - $invalidOperationException.ToString(), + $notImplementedException.ToString(), 'MachineStateIncorrect', 'NotImplemented', $null From d5958f4933ee7edae13ce37878b20825eb48f03a Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Tue, 23 Jan 2024 08:02:33 +0100 Subject: [PATCH 4/7] Fix comment-based help --- source/Public/New-Exception.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/Public/New-Exception.ps1 b/source/Public/New-Exception.ps1 index a364e3d..1bb5391 100644 --- a/source/Public/New-Exception.ps1 +++ b/source/Public/New-Exception.ps1 @@ -3,7 +3,7 @@ Creates and returns an exception. .DESCRIPTION - Creates and returns an exception. + Creates an exception that will be returned. .OUTPUTS None From ea68b0d14dfa89d67b3fcec2ae4389f555fae83d Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Tue, 23 Jan 2024 08:31:08 +0100 Subject: [PATCH 5/7] Fix comment-based help --- source/Public/New-InvalidDataException.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/Public/New-InvalidDataException.ps1 b/source/Public/New-InvalidDataException.ps1 index fcf3431..11e45f7 100644 --- a/source/Public/New-InvalidDataException.ps1 +++ b/source/Public/New-InvalidDataException.ps1 @@ -11,7 +11,7 @@ .PARAMETER ErrorId The error Id to assign to the exception. - .PARAMETER ErrorMessage + .PARAMETER Message The error message to assign to the exception. .EXAMPLE From 6da56902007f2dda75d688a9d4408defb647caa2 Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Tue, 23 Jan 2024 08:59:50 +0100 Subject: [PATCH 6/7] Fix missed variable rename --- source/Public/New-NotImplementedException.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/Public/New-NotImplementedException.ps1 b/source/Public/New-NotImplementedException.ps1 index d42cd70..525aa65 100644 --- a/source/Public/New-NotImplementedException.ps1 +++ b/source/Public/New-NotImplementedException.ps1 @@ -80,7 +80,7 @@ function New-NotImplementedException if ($PassThru.IsPresent) { - return $invalidOperationException + return $notImplementedException } else { From 8495e30ac419b3be02a53284265620d37519b592 Mon Sep 17 00:00:00 2001 From: Johan Ljunggren Date: Tue, 23 Jan 2024 09:46:58 +0100 Subject: [PATCH 7/7] Fix unit test x-plat --- tests/Unit/Public/New-ArgumentException.Tests.ps1 | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/tests/Unit/Public/New-ArgumentException.Tests.ps1 b/tests/Unit/Public/New-ArgumentException.Tests.ps1 index c7fa236..33db675 100644 --- a/tests/Unit/Public/New-ArgumentException.Tests.ps1 +++ b/tests/Unit/Public/New-ArgumentException.Tests.ps1 @@ -77,7 +77,18 @@ Describe 'New-ArgumentException' { $result = New-ArgumentException -Message $mockErrorMessage -ArgumentName $mockArgumentName -PassThru $result | Should -BeOfType 'System.ArgumentException' - $result.Message | Should -Be ("{0} (Parameter '{1}')" -f $mockErrorMessage, $mockArgumentName) + <# + There is a difference between how Windows PowerShell and PowerShell + outputs this error message. The regular expression handles both cases. + + Windows PowerShell message: + Mocked error + Parameter name: MockArgument + + PowerShell message: + Mocked error (Parameter 'MockArgument') + #> + $result.Message | Should -Match ("{0}\r?\n?.*\(?Parameter (?:name: )?'?{1}'?\)?" -f $mockErrorMessage, $mockArgumentName) $result.ParamName | Should -Be $mockArgumentName } }