-
Notifications
You must be signed in to change notification settings - Fork 0
/
SPECviewperf13_CompleteCheck.psm1
68 lines (43 loc) · 1.67 KB
/
SPECviewperf13_CompleteCheck.psm1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
function SPECviewperf13_CompleteCheck {
Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Bypass -Force
$wshell = New-Object -com WScript.Shell
Add-Type -AssemblyName Microsoft.VisualBasic
Add-Type -AssemblyName System.Windows.Forms
if($PSScriptRoot.length -eq 0){
$scriptRoot="C:\testing_AI\modules"
}
else{
$scriptRoot=$PSScriptRoot
}
$action="SPECviewperf13 job completed check"
$tcpath=(Split-Path -Parent $scriptRoot)+"\currentjob\TC.txt"
$tcnumber=((get-content $tcpath).split(","))[0]
$tcstep=((get-content $tcpath).split(","))[1]
$picpath=(Split-Path -Parent $scriptRoot)+"\logs\$($tcnumber)\"
$taskExists = Get-ScheduledTask | Where-Object {$_.TaskName -like "Auto_Run" }
if($taskExists -eq $null){
$results="-"
$index= "SPECviewperf13 no execute"
}
else{
$doneflag=$null
$startruntime=(Get-ChildItem C:\SPEC\SPECgpc\SPECviewperf13\vp13bench\gwpgRunBenchmark.js).LastWriteTime
$resultfd=Get-ChildItem -Path C:\SPEC\SPECgpc\SPECviewperf13\results_* -Directory|Where-object{$_.CreationTime -gt $startruntime}
if( $resultfd.count -eq 0){
exit
}
else{
start-process cmd -ArgumentList '/c schtasks /delete /TN "Auto_Run" -f'
Copy-Item -Path $resultfd.FullName -Destination $picpath -Recurse -Force
$results="OK"
$index= $resultfd.name
}
}
### write log ##
Get-Module -name "outlog"|remove-module
$mdpath=(Get-ChildItem -path "C:\testing_AI\modules\" -r -file |Where-object{$_.name -match "outlog" -and $_.name -match "psm1"}).fullname
Import-Module $mdpath -WarningAction SilentlyContinue -Global
#write-host "Do $action!"
outlog $action $results $tcnumber $tcstep $index
}
export-modulemember -Function SPECviewperf13_CompleteCheck