1*** Settings ***
2Documentation    Stress the system GPUs using the HTX exerciser.
3
4# Test Parameters:
5# OPENBMC_HOST        The BMC host name or IP address.
6# OS_HOST             The OS host name or IP Address.
7# OS_USERNAME         The OS login userid (usually "root").
8# OS_PASSWORD         The password for the OS login.
9# HTX_DURATION        Duration of HTX run, for example, "2h", or "30m".
10# HTX_LOOP            The number of times to loop HTX.
11# HTX_INTERVAL        The time delay between consecutive checks of HTX
12#                     status, for example, "15m".
13#                     In summary: Run HTX for $HTX_DURATION, looping
14#                     $HTX_LOOP times checking for errors every
15#                     $HTX_INTERVAL.  Then allow extra time for OS
16#                     Boot, HTX startup, shutdown.
17# HTX_KEEP_RUNNING    If set to 1, this indicates that the HTX is to
18#                     continue running after an error was found.
19
20
21Resource         ../lib/os_utilities.robot
22
23Suite Setup      Run Keyword  Start SOL Console Logging
24Test Setup       Test Setup Execution
25Test Teardown    Test Teardown Execution
26
27Test Tags       GPU_Stress
28
29*** Variables ****
30
31${HTX_DURATION}      1h
32${HTX_LOOP}          ${1}
33${HTX_INTERVAL}      30m
34${HTX_KEEP_RUNNING}  ${0}
35${stack_mode}        skip
36
37*** Test Cases ***
38
39GPU Stress Test
40    [Documentation]  Stress the GPU using HTX exerciser.
41    [Tags]  GPU_Stress_Test
42
43    # Get number of GPU reported by the BMC.
44    ${num_bmc_gpus}=  Count GPUs From BMC
45    Rpvars  num_bmc_gpus
46
47    # The BMC and OS should report the same number of GPUs.
48    ${failmsg01}=  Catenate  OS reports ${num_os_gpus} GPUs, but BMC
49    ...  reports ${num_bmc_gpus} present and functional GPUs.
50    Run Keyword If  '${num_os_gpus}' != '${num_bmc_gpus}'
51    ...  Fail  msg=${failmsg01}
52
53    # Show parameters for HTX stress test.
54    Printn
55    Rpvars  HTX_DURATION  HTX_LOOP  HTX_INTERVAL
56
57    # Set the iteration (loop) counter.
58    Set Suite Variable  ${iteration}  ${0}  children=true
59
60
61    # Shutdown HTX if it is already running.
62    ${status}=  Is HTX Running
63    Run Keyword If  '${status}' == 'True'
64    ...  Shutdown HTX Exerciser
65
66    Repeat Keyword  ${HTX_LOOP} times  Execute GPU Test
67
68
69*** Keywords ***
70
71Execute GPU Test
72    [Documentation]  Start HTX exerciser.
73    # Test Flow:
74    #              - Power on
75    #              - Establish SSH connection session
76    #              - Collect GPU nvidia status output
77    #              - Create HTX mdt profile
78    #              - Run GPU specific HTX exerciser
79    #              - Check for errors
80
81    Set Suite Variable  ${iteration}  ${iteration + 1}
82    ${loop_count}=  Catenate  Starting iteration: ${iteration}
83    Printn
84    Rpvars  loop_count
85
86    REST Power On  stack_mode=skip
87    Run Key U  Sleep \ 15s
88
89    # Collect data before the test starts.
90    Collect NVIDIA Log File  start
91
92    # Collect NVIDIA maximum limits.
93    ${power_max}=  Get GPU Power Limit
94    ${temperature_max}=  Get GPU Temperature Limit
95    ${clock_max}=  Get GPU Clock Limit
96
97    Run Keyword If  '${HTX_MDT_PROFILE}' == 'mdt.bu'
98    ...  Create Default MDT Profile
99
100    Run MDT Profile
101
102    Loop HTX Health Check
103
104    # Post test loop look out for dmesg error logged.
105    Check For Errors On OS Dmesg Log
106
107    # Check NVIDIA power, temperature, and clocks.
108    ${power}=  Get GPU Max Power
109    ${temperature}=  Get GPU Max Temperature
110    ${temperature_via_rest}=  Get GPU Temperature Via REST
111    ${clock}=  Get GPU Clock
112    Printn
113    Rpvars  power  power_max  temperature  temperature_via_rest
114    ...  temperature_max  clock  clock_max
115
116    Run Keyword If  ${power} > ${power_max}  Fail
117    ...  msg=GPU Power ${power} exceeds limit of ${power_max}.
118
119    ${err_msg}=  Catenate  GPU temperature of ${temperature} exceeds limit
120    ...  of ${temperature_max}.
121    Run Keyword If  ${temperature} > ${temperature_max}  Fail  msg=${err_msg}
122
123    Run Keyword If  ${clock} > ${clock_max}  Fail
124    ...  msg=GPU clock of ${clock} exceeds limit of ${clock_max}.
125
126    ${err_msg}=  Catenate  The GPU temperature reported by REST is not within
127    ...  5 degrees of the nvidia_smi reported temperature.
128    ${upper_limit}=  Evaluate  ${temperature_via_rest}+5
129    ${lower_limit}=  Evaluate  ${temperature_via_rest}-5
130    Run Keyword If
131    ...  ${temperature} > ${upper_limit} or ${temperature} < ${lower_limit}
132    ...  Fail  msg=${err_msg}
133
134    Shutdown HTX Exerciser
135
136    Collect NVIDIA Log File  end
137    Error Logs Should Not Exist
138    REST Power Off
139
140    Flush REST Sessions
141
142    Print Timen  HTX Test ran for: ${HTX_DURATION}
143
144    ${loop_count}=  Catenate  Ending iteration: ${iteration}
145    Printn
146    Rpvars  loop_count
147
148
149Loop HTX Health Check
150    [Documentation]  Run until HTX exerciser fails.
151
152    Repeat Keyword  ${HTX_DURATION}
153    ...  Run Keywords  Check HTX Run Status
154    ...  AND  Sleep  ${HTX_INTERVAL}
155
156
157Test Setup Execution
158    [Documentation]  Do the initial test setup.
159
160    REST Power On  stack_mode=skip
161    Run Key U  Sleep \ 15s
162    Delete All Error Logs
163    Tool Exist  lspci
164    Tool Exist  htxcmdline
165    Tool Exist  nvidia-smi
166
167    # Get number of GPUs reported by the OS.
168    ${cmd}=  Catenate  lspci | grep NVIDIA | wc -l
169    ${num_os_gpus}  ${stderr}  ${rc}=  OS Execute Command  ${cmd}
170    Printn
171    Rpvars  num_os_gpus
172
173    # If no GPUs detected, we cannot continue.
174    Run Keyword If  '${num_os_gpus}' == '${0}'  Fail
175    ...  msg=No GPUs detected so cannot run test.
176
177    Set Suite Variable  ${num_os_gpus}  children=true
178
179
180
181Test Teardown Execution
182    [Documentation]  Do the post test teardown.
183
184    # Keep HTX running if user set HTX_KEEP_RUNNING to 1.
185    Run Keyword If  '${TEST_STATUS}' == 'FAIL' and ${HTX_KEEP_RUNNING} == ${0}
186    ...  Shutdown HTX Exerciser
187
188    ${keyword_buf}=  Catenate  Stop SOL Console Logging
189    ...  \ targ_file_path=${EXECDIR}${/}logs${/}SOL.log
190    Run Key  ${keyword_buf}
191
192    FFDC On Test Case Fail
193    Close All Connections
194