ps/Modules/Alkami.PowerShell.Services/Public/Test-RadiumMetaData.ps1
2023-05-30 22:51:22 -07:00

67 lines
2.1 KiB
PowerShell

function Test-RadiumMetaData {
<#
.SYNOPSIS
Tests that dbo.JobMetaData contains some work, and that the number of failed jobs is less than 5% of the total number of jobs
#>
param(
)
$masterConnectionString = Get-MasterConnectionString
try {
$conn = New-Object System.Data.SqlClient.SqlConnection
$conStrBuilder = New-Object System.Data.SqlClient.SqlConnectionStringBuilder($masterConnectionString)
$conn.ConnectionString = $conStrBuilder.ToString()
$conn.Open()
$command = New-Object System.Data.SqlClient.SqlCommand("select Status, Count(status) as count from dbo.JobMetadata where RunDateTimeUtc > DateADD(mi, -30, GETUTCDATE()) group by status", $conn)
$adapter = New-Object System.Data.sqlclient.sqlDataAdapter $command
$dataset = New-Object System.Data.DataSet
$adapter.Fill($dataSet) | Out-Null
$failedJobs = 0
$totalJobs = 0
$successfullJobs = 0
$dataset.Tables[0].Rows | ForEach-Object {
if ($_.Status -eq 4) {
$failedJobs += $_.Count
}
if ($_.Status -eq 2) {
$successfullJobs += $_.Count
}
$totalJobs += $_.Count
}
if (($successfullJobs -eq 0) -and ($totalJobs -gt 0)) {
throw "No jobs have been successful in last 10 minutes, even though $totalJobs have ran"
}
if (($totalJobs -gt 0) -and (($failedJobs / $totalJobs) -gt .005)) {
throw "the number of failed jobs exceeded 5% $failedJobs occurred out of $totalJobs"
}
Write-Host "There are $totalJobs total jobs $failedJobs failed jobs, and $successfullJobs successful jobs in the last 10 minutes "
}
catch {
$warning = "An exception occurred while trying to Check Radium Triggers"
Write-Warning $warning
Write-Warning $error[0] | Format-List -Force
throw $warning
}
finally {
if ($conn.State -ne [System.Data.ConnectionState]::Closed) {
$conn.Close()
}
$conn = $null
}
}