tests/Test-CmComponentErrors.ps1
function Test-CmComponentErrors { [CmdletBinding()] [OutputType()] param ( [parameter()][string] $TestName = "Site Component Errors", [parameter()][string] $TestGroup = "operation", [parameter()][string] $TestCategory = "CM", [parameter()][string] $Description = "Site Component Errors and Warnings", [parameter()][hashtable] $ScriptParams ) try { $startTime = (Get-Date) #[int]$Setting = Get-CmHealthDefaultValue -KeySet "keygroup:keyname" -DataSet $CmHealthConfig [System.Collections.Generic.List[PSObject]]$tempdata = @() # for detailed test output to return if needed $stat = "PASS" # do not change this $except = "WARNING" # or "FAIL" $msg = "No issues found" # do not change this either $query = "Select ComponentName, ComponentType, Case when Status = 0 then 'OK' when Status = 1 then 'Warning' when Status = 2 then 'Critical' End as 'Status', Case when State = 0 then 'Stopped' when State = 1 then 'Started' when State = 2 then 'Paused' when State = 3 then 'Installing' when State = 4 then 'Re-installing' when State = 5 then 'De-installing' End as 'State', Case When AvailabilityState = 0 then 'Online' When AvailabilityState = 3 then 'Offline' When AvailabilityState = 4 then 'Unknown' End as 'AvailabilityState', Infos, Warnings, Errors from vSMS_ComponentSummarizer where TallyInterval = N'0001128000100008' and MachineName = 'vm-sccmsite-01.uhs.med' and SiteCode = 'S02' and Status in (1,2) Order by Status,ComponentName" $res = Get-CmSqlQueryResult -Query $query -Params $ScriptParams if ($res.Count -gt 0) { $stat = $except $msg = "$($res.Count) component status issues found" $res | Foreach-Object { $tempdata.Add( [pscustomobject]@{ ComponentName = $_.ComponentName ComponentType = $_.ComponentType Status = $_.Status State = $_.State AvailabilityState = $_.AvailabilityState Info = $_.Infos Warnings = $_.Warnings Errors = $_.Errors } ) } } } catch { $stat = 'ERROR' $msg = $_.Exception.Message -join ';' } finally { Set-CmhOutputData } } |