From 3ce23836fc504b9d08743035b060f6f5c83790fd Mon Sep 17 00:00:00 2001 From: David Paulson Date: Wed, 8 May 2024 16:53:05 -0500 Subject: [PATCH] Add Try Catch for write to screen --- .../HealthChecker/Writers/Write-Functions.ps1 | 25 +++++--- .../Writers/Write-ResultsToScreen.ps1 | 62 +++++++++++-------- 2 files changed, 54 insertions(+), 33 deletions(-) diff --git a/Diagnostics/HealthChecker/Writers/Write-Functions.ps1 b/Diagnostics/HealthChecker/Writers/Write-Functions.ps1 index 2fda00431f..a54e1ed100 100644 --- a/Diagnostics/HealthChecker/Writers/Write-Functions.ps1 +++ b/Diagnostics/HealthChecker/Writers/Write-Functions.ps1 @@ -40,14 +40,23 @@ function Write-HostLog ($message) { function Write-OutColumns($OutColumns) { if ($null -ne $OutColumns) { - $stringOutput = $null - $OutColumns.DisplayObject | - Out-Columns -Properties $OutColumns.SelectProperties ` - -ColorizerFunctions $OutColumns.ColorizerFunctions ` - -IndentSpaces $OutColumns.IndentSpaces ` - -StringOutput ([ref]$stringOutput) - $stringOutput | Out-File ($Script:OutputFullPath) -Append - Write-DebugLog $stringOutput + try { + $stringOutput = $null + $params = @{ + Properties = $OutColumns.SelectProperties + ColorizerFunctions = $OutColumns.ColorizerFunctions + IndentSpaces = $OutColumns.IndentSpaces + StringOutput = ([ref]$stringOutput) + } + $OutColumns.DisplayObject | Out-Columns @params + $stringOutput | Out-File ($Script:OutputFullPath) -Append + Write-DebugLog $stringOutput + } catch { + # We do not want to call Invoke-CatchActions here because we want the issues reported. + Write-Verbose "Failed to export Out-Columns. Inner Exception: $_" + $s = $OutColumns.DisplayObject | Out-String + Write-DebugLog $s + } } } diff --git a/Diagnostics/HealthChecker/Writers/Write-ResultsToScreen.ps1 b/Diagnostics/HealthChecker/Writers/Write-ResultsToScreen.ps1 index 4ed3ec0fac..7af275a172 100644 --- a/Diagnostics/HealthChecker/Writers/Write-ResultsToScreen.ps1 +++ b/Diagnostics/HealthChecker/Writers/Write-ResultsToScreen.ps1 @@ -20,36 +20,48 @@ function Write-ResultsToScreen { Write-Verbose "Working on Key Group: $($keyGrouping.Name)" Write-Verbose "Total lines to write: $($ResultsToWrite[$keyGrouping].Count)" - if ($keyGrouping.DisplayGroupName) { - Write-Grey($keyGrouping.Name) - $dashes = [string]::empty - 1..($keyGrouping.Name.Length) | ForEach-Object { $dashes = $dashes + "-" } - Write-Grey($dashes) - } + try { + if ($keyGrouping.DisplayGroupName) { + Write-Grey($keyGrouping.Name) + $dashes = [string]::empty + 1..($keyGrouping.Name.Length) | ForEach-Object { $dashes = $dashes + "-" } + Write-Grey($dashes) + } - foreach ($line in $ResultsToWrite[$keyGrouping]) { - $tab = [string]::Empty + foreach ($line in $ResultsToWrite[$keyGrouping]) { + try { + $tab = [string]::Empty - if ($line.TabNumber -ne 0) { - 1..($line.TabNumber) | ForEach-Object { $tab = $tab + "`t" } - } + if ($line.TabNumber -ne 0) { + 1..($line.TabNumber) | ForEach-Object { $tab = $tab + "`t" } + } - if ([string]::IsNullOrEmpty($line.Name)) { - $displayLine = $line.DisplayValue - } else { - $displayLine = [string]::Concat($line.Name, ": ", $line.DisplayValue) - } + if ([string]::IsNullOrEmpty($line.Name)) { + $displayLine = $line.DisplayValue + } else { + $displayLine = [string]::Concat($line.Name, ": ", $line.DisplayValue) + } - $writeValue = "{0}{1}" -f $tab, $displayLine - switch ($line.WriteType) { - "Grey" { Write-Grey($writeValue) } - "Yellow" { Write-Yellow($writeValue) } - "Green" { Write-Green($writeValue) } - "Red" { Write-Red($writeValue) } - "OutColumns" { Write-OutColumns($line.OutColumns) } + $writeValue = "{0}{1}" -f $tab, $displayLine + switch ($line.WriteType) { + "Grey" { Write-Grey($writeValue) } + "Yellow" { Write-Yellow($writeValue) } + "Green" { Write-Green($writeValue) } + "Red" { Write-Red($writeValue) } + "OutColumns" { Write-OutColumns($line.OutColumns) } + } + } catch { + # We do not want to call Invoke-CatchActions here because we want the issues reported. + Write-Verbose "Failed inside the section loop writing. Writing out a blank line and continuing. Inner Exception: $_" + Write-Grey "" + } } - } - Write-Grey("") + Write-Grey "" + } catch { + # We do not want to call Invoke-CatchActions here because we want the issues reported. + Write-Verbose "Failed in $($MyInvocation.MyCommand) outside section writing loop. Inner Exception: $_" + Write-Grey "" + } } }