-
Notifications
You must be signed in to change notification settings - Fork 0
/
getresult.psm1
95 lines (67 loc) · 3.49 KB
/
getresult.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
function getresult([string]$para1){
Set-ExecutionPolicy -Scope CurrentUser -ExecutionPolicy Bypass -Force;
#$wshell=New-Object -ComObject wscript.shell
Add-Type -AssemblyName Microsoft.VisualBasic
Add-Type -AssemblyName System.Windows.Forms
Add-Type -AssemblyName System.Windows.Forms,System.Drawing
$paracheck=$PSBoundParameters.ContainsKey('para1')
if( $paracheck -eq $false -or $para1.length -eq 0 ){
#write-host "no defined, setting 1 min after login"
$para1="passmark"
}
$result_type=$para1
$action = "get results - $result_type"
if($PSScriptRoot.length -eq 0){
$scriptRoot="C:\testing_AI\modules"
}
else{
$scriptRoot=$PSScriptRoot
}
$tcpath=(Split-Path -Parent $scriptRoot)+"\currentjob\TC.txt"
$tcnumber=((get-content $tcpath).split(","))[0]
$tcstep=((get-content $tcpath).split(","))[1]
$logpath=(Split-Path -Parent $scriptRoot)+"\logs\$($tcnumber)\$($tcstep)_$($result_type)_results\"
if(!(test-path $logpath)){new-item -ItemType directory -path $logpath |out-null}
#$width = ([string]::Join("`n", (wmic path Win32_VideoController get CurrentHorizontalResolution))).split("`n") -match "\d{1,}"
#$height = ([string]::Join("`n", (wmic path Win32_VideoController get CurrentVerticalResolution))).split("`n") -match "\d{1,}"
$results="OK"
$Index="check $($logpath) result folder"
if($result_type -match "passmark"){
$resultfile=Get-ChildItem -path C:\testing_AI\logs\passmark*.log
if($resultfile.count -ne 0){
move-Item C:\testing_AI\logs\passmark*.log $logpath -Force
move-Item C:\testing_AI\logs\passmark*.htm $logpath -Force
}
else{
$results="NG"
$Index= "No results. please check bitconfig settings"
}
}
if($result_type -match "3dmark"){
#$getlasttime=(Get-ChildItem -path C:\testing_AI\logs\logs_timemap.csv).lastwritetime
#$nowtime=get-date
#$gaps=(New-TimeSpan -Start $getlasttime -end $nowtime).TotalMinutes
$Index=""
$resultfile=Get-ChildItem -path $env:USERPROFILE\documents\3DMark\3DMark.log -ErrorAction SilentlyContinue
$resultfile2=Get-ChildItem -path $env:USERPROFILE\documents\3DMark\*.3dmark-result -ErrorAction SilentlyContinue
$resultfile3=Get-ChildItem -path $env:USERPROFILE\documents\3DMark\*.xml -ErrorAction SilentlyContinue
$resultfile32=Get-ChildItem -path $env:USERPROFILE\documents\*.xml -ErrorAction SilentlyContinue
## finish with log ###
if($resultfile.count -ne 0){copy-Item $env:USERPROFILE\documents\3DMark\3DMark.log $logpath -Force}
if($resultfile2.count -ne 0){copy-Item $env:USERPROFILE\documents\3DMark\*.3dmark-result $logpath -Force}
if($resultfile3.count -ne 0){copy-Item $env:USERPROFILE\documents\3DMark\*.xml $logpath -Force}
if($resultfile32.count -ne 0){copy-Item $env:USERPROFILE\documents\*.xml $logpath -Force}
remove-item "$env:userprofile\Documents\3DMark\*.3dmark-result" -Force -ErrorAction SilentlyContinue
#remove-item "$env:userprofile\Documents\3DMark\3DMark.log" -Force -ErrorAction SilentlyContinue
remove-item "$env:userprofile\Documents\3DMark\*.xml" -Force -ErrorAction SilentlyContinue
remove-item "$env:userprofile\Documents\*.xml" -Force -ErrorAction SilentlyContinue
}
########### 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 getresult