2024-02-08 22:08:33 +01:00
|
|
|
enum State {
|
|
|
|
Started
|
|
|
|
Finished
|
|
|
|
Failed
|
|
|
|
}
|
|
|
|
|
|
|
|
function GetVMName {
|
|
|
|
param (
|
|
|
|
[string]$Rest
|
|
|
|
)
|
|
|
|
$tokens = $Rest -split "'"
|
|
|
|
return $tokens[1]
|
|
|
|
}
|
|
|
|
|
|
|
|
function ConvertDate {
|
|
|
|
param (
|
|
|
|
[string]$DateString
|
|
|
|
)
|
|
|
|
return [DateTime]$DateString
|
|
|
|
}
|
|
|
|
|
|
|
|
function DeterminState {
|
|
|
|
param (
|
|
|
|
[String]$Rest
|
|
|
|
)
|
|
|
|
if($Rest.IndexOf("Erfolgreiche") -cge 0){
|
|
|
|
return 'Finished'
|
|
|
|
} elseif ($Rest.IndexOf("gestartet") -cge 0) {
|
|
|
|
return 'Started'
|
|
|
|
} else {
|
|
|
|
return 'Failed'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function ProduceHashMap {
|
|
|
|
param (
|
|
|
|
$Elements
|
|
|
|
)
|
|
|
|
$HashTable =@{}
|
2024-02-08 22:54:01 +01:00
|
|
|
foreach ($elem in $Elements){
|
|
|
|
$indexOfFirst = $elem.IndexOf(" ")
|
|
|
|
if($indexOfFirst -le 0){
|
|
|
|
continue
|
2024-02-08 22:08:33 +01:00
|
|
|
}
|
2024-02-08 22:54:01 +01:00
|
|
|
$date = $elem.SubString(0,$elem.IndexOf(" ",($indexOfFirst + 1)))
|
|
|
|
$rest = $elem.Substring($elem.IndexOf(" ",($indexOfFirst + 1))+1)
|
|
|
|
$vmName = GetVMName($rest)
|
|
|
|
$backUpState = DeterminState($rest)
|
|
|
|
$timeStamp
|
|
|
|
if($HashTable.ContainsKey($vmName)){
|
|
|
|
$array = $HashTable[$vmName]
|
2024-02-08 23:19:09 +01:00
|
|
|
$lastState=($array[$array.Count-1]).state
|
2024-02-08 23:23:36 +01:00
|
|
|
#Write-Host $lastState
|
|
|
|
#Write-Host $backUpState
|
2024-02-08 23:19:09 +01:00
|
|
|
if (($lastState -eq 'Failed') -and ($backUpState -eq 'Failed')) {
|
2024-02-08 23:23:36 +01:00
|
|
|
#Write-Host "skipping"
|
2024-02-08 23:19:09 +01:00
|
|
|
continue
|
|
|
|
}
|
2024-02-08 23:23:36 +01:00
|
|
|
#Write-Host "continuing"
|
2024-02-08 22:54:01 +01:00
|
|
|
try {
|
|
|
|
$timeStamp = ConvertDate($date)
|
|
|
|
$array += New-Object psobject -Property @{
|
|
|
|
state = $backUpState
|
|
|
|
ts = $timeStamp
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch {
|
|
|
|
foreach ($i in (($array.Count-1)..0)){
|
2024-02-08 23:19:09 +01:00
|
|
|
#Write-Host $array[$i]
|
2024-02-08 22:54:01 +01:00
|
|
|
if ($array[$i]["state"] -eq 'Started') {
|
2024-02-08 23:19:09 +01:00
|
|
|
#Write-Host "found started"
|
|
|
|
$timeStamp = ($array[$i]).ts
|
2024-02-08 22:54:01 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
$array += New-Object psobject -Property @{
|
|
|
|
state = $backUpState
|
|
|
|
ts = $timeStamp
|
|
|
|
}
|
|
|
|
}
|
|
|
|
$HashTable[$vmName]=$array
|
|
|
|
} else {
|
|
|
|
try {
|
|
|
|
$timeStamp = ConvertDate($date)
|
|
|
|
$HashTable += @{$vmName=@(New-Object psobject -Property @{
|
|
|
|
state = $backUpState
|
|
|
|
ts = $timeStamp
|
|
|
|
})}
|
|
|
|
}
|
|
|
|
catch {
|
|
|
|
<#Do nothing as key is empty and failed state#>
|
|
|
|
}
|
|
|
|
}
|
2024-02-08 22:08:33 +01:00
|
|
|
}
|
2024-02-08 22:54:01 +01:00
|
|
|
return $HashTable
|
2024-02-08 22:08:33 +01:00
|
|
|
}
|
|
|
|
|
2024-02-08 22:20:38 +01:00
|
|
|
function getElems {
|
|
|
|
param (
|
|
|
|
$Path
|
|
|
|
)
|
|
|
|
$lines = Get-Content -Path $Path | ForEach-Object {$_.SubString($_.IndexOf(":")+1)}
|
|
|
|
$elems = $lines | Out-String -Stream | Select-String -Pattern "VMware-Maschine" | Out-String -Stream
|
|
|
|
return $elems
|
|
|
|
}
|
|
|
|
|
|
|
|
function ProcessLogToHash {
|
|
|
|
param (
|
|
|
|
$Path
|
|
|
|
)
|
|
|
|
ProduceHashMap -Elements $(getElems -Path $Path)
|
2024-02-08 23:19:09 +01:00
|
|
|
}
|