blob: 1a4b5d9940c48065dda39c8d97090f9591b2862e [file] [log] [blame] [edit]
*** Settings ***
Documentation This suite tests IPMI Cold Reset in OpenBMC.
...
... The Cold reset command directs the Responder to perform
... a 'Cold Reset' action, which causes default setting of
... interrupt enables, event message generation,sensor scanning,
... threshold values, and other 'power up' default state to be restored.
...
... The script consist of 3 testcases:
... - Cold_Reset_Via_IPMI
... - Cold_Reset_With_Invalid_Data_Request_Via_IPMI
... - Verify_Cold_Reset_Impact_On_Sensor_Threshold_Via_IPMI
...
... The script verifies command execution for cold reset,
... invalid data request verification of cold reset and
... impact on sensor threshold value change with cold reset.
...
... The script changes sensor threshold value for Fan sensor,
... executes cold reset IPMI command,
... compares sensor threshold values of initial and reading after cold reset.
...
... Request data for cold reset present under data/ipmi_raw_cmd_table.py
Resource ../lib/ipmi_client.robot
Resource ../lib/openbmc_ffdc.robot
Library Collections
Library ../lib/ipmi_utils.py
Variables ../data/ipmi_raw_cmd_table.py
Test Teardown FFDC On Test Case Fail
Force Tags IPMI_Cold_Reset
*** Variables ***
${NETWORK_RESTART_TIME} 30s
@{thresholds_list} lcr lnc unc ucr
*** Test Cases ***
Cold Reset Via IPMI
[Documentation] Verify Cold Reset via IPMI.
[Tags] Cold_Reset_Via_IPMI
# Cold Reset Via IPMI raw command.
Run External IPMI Raw Command ${IPMI_RAW_CMD['Cold Reset']['reset'][0]}
# Get the BMC Status.
Wait Until Keyword Succeeds 3 min 10 sec Is BMC Unpingable
Wait Until Keyword Succeeds 3 min 10 sec Is BMC Operational
# Verify if BMC restarted with Get Device ID command.
${resp}= Run External IPMI Raw Command ${IPMI_RAW_CMD['Device ID']['Get'][0]}
Should Not Contain ${resp} ${IPMI_RAW_CMD['Device ID']['Get'][1]}
Cold Reset With Invalid Data Request Via IPMI
[Documentation] Verify Cold Reset with invalid data request via IPMI.
[Tags] Cold_Reset_With_Invalid_Data_Request_Via_IPMI
# Verify cold reset with invalid length of the request data and expect error.
${resp}= Run Keyword and Expect Error *Request data length invalid*
... Run External IPMI Raw Command ${IPMI_RAW_CMD['Cold Reset']['reset'][0]} 0x00
Verify Cold Reset Impact On Sensor Threshold Via IPMI
[Documentation] Modify sensor threshold, perform cold reset,
... and verify if sensor threshold reverts back to initial value.
[Tags] Verify_Cold_Reset_Impact_On_Sensor_Threshold_Via_IPMI
# Get sensor list.
${sensor_list}= Get Sensor List
# Get initial sensor threshold readings.
${sensor_name} ${sensor_threshold}= Get The Sensor Name And Threshold ${sensor_list}
${threshold_key_list}= Get Dictionary Keys ${sensor_threshold}
${random_threshold_key}= Evaluate random.choice(${threshold_key_list}) random
${old_threshold_value}= Get From Dictionary ${sensor_threshold} ${random_threshold_key}
# Modify Default Threshold Value For An Sensor To Set An New Threshold Value
${new_settable_threshold_value}= Modify Default Sensor Threshold Value ${old_threshold_value}
# Set/Get sensor threshold for given sensor and compare with initial reading.
${new_threshold_value}= Set And Get Sensor Threshold For given Sensor ${sensor_name} ${random_threshold_key}
... ${new_settable_threshold_value}
Should Not Be Equal ${new_threshold_value} ${old_threshold_value}
# Cold Reset Via IPMI raw command.
Run External IPMI Raw Command ${IPMI_RAW_CMD['Cold Reset']['reset'][0]}
# Get the BMC Status.
Wait Until Keyword Succeeds 3 min 10 sec Is BMC Unpingable
Wait Until Keyword Succeeds 10 min 10 sec Is BMC Operational
# Get sensor data for the sensor identified.
${data_after_coldreset}= Wait Until Keyword Succeeds 2 min 30 sec
... Run IPMI Standard Command sensor | grep -i "${sensor_name}"
# Get sensor threshold readings after BMC restarts.
${threshold_value_after_reset}= Getting Sensor Threshold Value Based On Threshold Key ${random_threshold_key} ${sensor_name}
# Compare with initial sensor threshold values.
Should Be Equal ${threshold_value_after_reset} ${old_threshold_value}
*** Keywords ***
Get Sensor List
[Documentation] To get the list of sensors via IPMI sensor list.
# BMC may take time to populate all the sensors once BMC Cold reset completes.
${data}= Wait Until Keyword Succeeds 2 min 30 sec
... Run IPMI Standard Command sensor
[Return] ${data}
Get The Sensor Name And Threshold
[Documentation] To get the sensor threshold for given sensor using IPMI.
[Arguments] ${sensor_list}
# Description of Argument(s):
# ${sensor_list} All the sensors listed with ipmi sensor list command.
@{tmp_list}= Create List
@{sensor_list_lines}= Split To Lines ${sensor_list}
# Omit the discrete sensor and create an threshold sensor name list
FOR ${sensor} IN @{sensor_list_lines}
${discrete_sensor_status}= Run Keyword And Return Status Should Contain ${sensor} discrete
Continue For Loop If '${discrete_sensor_status}' == 'True'
${sensor_details}= Split String ${sensor} |
${get_sensor_name}= Get From List ${sensor_details} 0
${sensor_name}= Set Variable ${get_sensor_name.strip()}
Append To List ${tmp_list} ${sensor_name}
END
${sensor_count}= Get Length ${tmp_list}
FOR ${RANGE} IN RANGE 0 ${sensor_count}
${random_sensor} ${sensor_threshold}= Selecting Random Sensor Name And Threshold Value ${tmp_list} ${sensor_list}
${threshold_dict_count}= Get Length ${sensor_threshold}
Exit For Loop If '${threshold_dict_count}' != '0'
Remove Values From List ${tmp_list} ${random_sensor}
END
[Return] ${random_sensor} ${sensor_threshold}
Selecting Random Sensor Name And Threshold Value
[Documentation] Select Random Sensor Name And Threshold Values.
[Arguments] ${tmp_list} ${sensor_list}
# Selecting random sensors from sensor list
${random_sensor_name}= Evaluate random.choice(${tmp_list}) random
# Create Dictionary For Threshold Key With Threshold Values
&{tmp_dict}= Create Dictionary
${sensor_threshold}= Get Lines Containing String ${sensor_list} ${random_sensor_name}
@{ipmi_sensor}= Split String ${sensor_threshold} |
${get_ipmi_lower_non_recoverable_threshold}= Get From List ${ipmi_sensor} 4
${ipmi_lower_non_recoverable_threshold}= Set Variable ${get_ipmi_lower_non_recoverable_threshold.strip()}
${lower_non_recoverable_threshold_status}= Run Keyword And Return Status Should Not Contain
... ${ipmi_lower_non_recoverable_threshold} na
Run Keyword If '${lower_non_recoverable_threshold_status}' == 'True'
... Set To Dictionary ${tmp_dict} lnr ${ipmi_lower_non_recoverable_threshold}
${get_ipmi_lower_critical_threshold}= Get From List ${ipmi_sensor} 5
${ipmi_lower_critical_threshold}= Set Variable ${get_ipmi_lower_critical_threshold.strip()}
${lower_critical_threshold_status}= Run Keyword And Return Status Should Not Contain
... ${ipmi_lower_critical_threshold} na
Run Keyword If '${lower_critical_threshold_status}' == 'True'
... Set To Dictionary ${tmp_dict} lcr ${ipmi_lower_critical_threshold}
${get_ipmi_lower_non_critical_threshold}= Get From List ${ipmi_sensor} 6
${ipmi_lower_non_critical_threshold}= Set Variable ${get_ipmi_lower_non_critical_threshold.strip()}
${lower_non_critical_threshold_status}= Run Keyword And Return Status Should Not Contain
... ${ipmi_lower_non_critical_threshold} na
Run Keyword If '${lower_non_critical_threshold_status}' == 'True'
... Set To Dictionary ${tmp_dict} lnc ${ipmi_lower_non_critical_threshold}
${get_ipmi_upper_non_critical_threshold}= Get From List ${ipmi_sensor} 7
${ipmi_upper_non_critical_threshold}= Set Variable ${get_ipmi_upper_non_critical_threshold.strip()}
${upper_non_critical_threshold_status}= Run Keyword And Return Status Should Not Contain
... ${ipmi_upper_non_critical_threshold} na
Run Keyword If '${upper_non_critical_threshold_status}' == 'True'
... Set To Dictionary ${tmp_dict} unc ${ipmi_upper_non_critical_threshold}
${get_ipmi_upper_critical_threshold}= Get From List ${ipmi_sensor} 8
${ipmi_upper_critical_threshold}= Set Variable ${get_ipmi_upper_critical_threshold.strip()}
${upper_critical_threshold_status}= Run Keyword And Return Status Should Not Contain
... ${ipmi_upper_critical_threshold} na
Run Keyword If '${upper_critical_threshold_status}' == 'True'
... Set To Dictionary ${tmp_dict} ucr ${ipmi_upper_critical_threshold}
${get_ipmi_upper_non_recoverable_threshold}= Get From List ${ipmi_sensor} 9
${ipmi_upper_non_recoverable_threshold}= Set Variable ${get_ipmi_upper_non_recoverable_threshold.strip()}
${upper_non_recoverable_threshold_status}= Run Keyword And Return Status Should Not Contain
... ${ipmi_upper_non_recoverable_threshold} na
Run Keyword If '${upper_non_recoverable_threshold_status}' == 'True'
... Set To Dictionary ${tmp_dict} unr ${ipmi_upper_non_recoverable_threshold}
[Return] ${random_sensor_name} ${tmp_dict}
Modify Default Sensor Threshold Value
[Documentation] Modify Default Sensor Threshold Value with adding 100 to old threshold values.
[Arguments] ${old_threshold}
${new_threshold}= Evaluate ${old_threshold} + 100
[Return] ${new_threshold}
Set And Get Sensor Threshold For given Sensor
[Documentation] Set/Get Sensor Threshold for given sensor Via IPMI.
[Arguments] ${sensor_name} ${random_threshold_key} ${new_settable_threshold_value}
# Set New Threshold Value To The Randomly Selected Sensor.
Run IPMI Standard Command sensor thresh "${sensor_name}" ${random_threshold_key} ${new_settable_threshold_value}
Sleep 10s
${sensor_new_threshold_value}= Getting Sensor Threshold Value Based On Threshold Key ${random_threshold_key} ${sensor_name}
[Return] ${sensor_new_threshold_value}
Getting Sensor Threshold Value Based On Threshold Key
[Documentation] Getting Particular Sensor Threshold Value Based On Sensor Name And Threshold Key.
[Arguments] ${threshold_key} ${sensor_name}
# After Setting Threshold Value, Get New Sensor Threshold Value.
${new_data}= Run IPMI Standard Command sensor | grep -i "${sensor_name}"
${new_sensor_details}= Split String ${new_data} |
${index_value}= Set Variable If
... '${threshold_key}' == 'lnr' ${4}
... '${threshold_key}' == 'lcr' ${5}
... '${threshold_key}' == 'lnc' ${6}
... '${threshold_key}' == 'unc' ${7}
... '${threshold_key}' == 'ucr' ${8}
... '${threshold_key}' == 'unr' ${9}
${get_sensor_new_threshold_value}= Get From List ${new_sensor_details} ${index_value}
${sensor_new_threshold_value}= Set Variable ${get_sensor_new_threshold_value.strip()}
[Return] ${sensor_new_threshold_value}