1*** Settings *** 2Documentation Test BMC Manager functionality. 3Resource ../../lib/resource.robot 4Resource ../../lib/bmc_redfish_resource.robot 5Resource ../../lib/common_utils.robot 6Resource ../../lib/openbmc_ffdc.robot 7Resource ../../lib/boot_utils.robot 8Resource ../../lib/open_power_utils.robot 9Resource ../../lib/bmc_network_utils.robot 10Library ../../lib/gen_robot_valid.py 11 12Test Setup Test Setup Execution 13Test Teardown Test Teardown Execution 14 15 16*** Variables *** 17 18${SYSTEM_SHUTDOWN_TIME} ${5} 19 20# Strings to check from journald. 21${REBOOT_REGEX} ^\-- Reboot -- 22 23*** Test Cases *** 24 25Verify Redfish BMC Firmware Version 26 [Documentation] Get firmware version from BMC manager. 27 [Tags] Verify_Redfish_BMC_Firmware_Version 28 29 Redfish.Login 30 ${resp}= Redfish.Get /redfish/v1/Managers/bmc 31 Should Be Equal As Strings ${resp.status} ${HTTP_OK} 32 ${bmc_version}= Get BMC Version 33 Should Be Equal As Strings 34 ... ${resp.dict["FirmwareVersion"]} ${bmc_version.strip('"')} 35 36 37Verify Redfish BMC Manager Properties 38 [Documentation] Verify BMC managers resource properties. 39 [Tags] Verify_Redfish_BMC_Manager_Properties 40 41 Redfish.Login 42 ${resp}= Redfish.Get /redfish/v1/Managers/bmc 43 Should Be Equal As Strings ${resp.status} ${HTTP_OK} 44 # Example: 45 # "Description": "Baseboard Management Controller" 46 # "Id": "bmc" 47 # "Model": "OpenBmc", 48 # "Name": "OpenBmc Manager", 49 # "UUID": "xxxxxxxx-xxx-xxx-xxx-xxxxxxxxxxxx" 50 # "PowerState": "On" 51 52 Should Be Equal As Strings 53 ... ${resp.dict["Description"]} Baseboard Management Controller 54 Should Be Equal As Strings ${resp.dict["Id"]} bmc 55 Should Be Equal As Strings ${resp.dict["Model"]} OpenBmc 56 Should Be Equal As Strings ${resp.dict["Name"]} OpenBmc Manager 57 Should Not Be Empty ${resp.dict["UUID"]} 58 Should Be Equal As Strings ${resp.dict["PowerState"]} On 59 60 61Verify MAC Address Property Is Populated 62 [Documentation] Verify BMC managers resource properties. 63 [Tags] Verify_MAC_Address_Property_Is_Populated 64 65 # Get OrderedDict from the BMC which contains active ethernet channel. 66 # Example: ([('1', {'name': 'eth0', 67 # 'is_valid': True, 68 # 'active_sessions': 0, 69 # 'channel_info': {'medium_type': 'lan-802.3', 70 # 'protocol_type': 'ipmb-1.0', 71 # 'session_supported': 'multi-session', 72 # 'is_ipmi': True 73 # } 74 # } 75 # )]) 76 77 ${active_channel_config}= Get Active Channel Config 78 79 FOR ${channel_number} IN @{active_channel_config.keys()} 80 Log Dictionary ${active_channel_config["${channel_number}"]} 81 82 # Get ethernet valid paths in redfish. 83 # Example: ['/redfish/v1/Managers/bmc/EthernetInterfaces'] 84 ${eth_interface}= redfish_utils.Get Endpoint Path List 85 ... /redfish/v1/Managers/ EthernetInterfaces 86 87 # Get the MACAddress attrivute value with the 'name': 'eth0'. 88 # Example: /redfish/v1/Managers/bmc/EthernetInterfaces/eth0 89 ${redfish_mac_addr}= Redfish.Get Attribute 90 ... ${eth_interface[0]}/${active_channel_config["${channel_number}"]["name"]} 91 ... MACAddress 92 END 93 94 Rprint Vars redfish_mac_addr fmt=terse 95 Valid Value redfish_mac_addr 96 97 ${ipaddr_mac_addr}= Get BMC MAC Address List 98 Rprint Vars ipaddr_mac_addr fmt=terse 99 100 List Should Contain Value ${ipaddr_mac_addr} ${redfish_mac_addr} 101 102 103Redfish BMC Manager GracefulRestart When Host Off 104 [Documentation] BMC graceful restart when host is powered off. 105 [Tags] Redfish_BMC_Manager_GracefulRestart_When_Host_Off 106 107 # "Actions": { 108 # "#Manager.Reset": { 109 # "ResetType@Redfish.AllowableValues": [ 110 # "GracefulRestart" 111 # ], 112 # "target": "/redfish/v1/Managers/bmc/Actions/Manager.Reset" 113 # } 114 115 ${test_file_path}= Set Variable /tmp/before_bmcreboot 116 BMC Execute Command touch ${test_file_path} 117 118 Redfish OBMC Reboot (off) 119 120 BMC Execute Command if [ -f ${test_file_path} ] ; then false ; fi 121 Verify BMC RTC And UTC Time Drift 122 123 # Check for journald persistency post reboot. 124 Check For Regex In Journald ${REBOOT_REGEX} error_check=${1} 125 126 127Verify Boot Count After BMC Reboot 128 [Documentation] Verify boot count increments on BMC reboot. 129 [Tags] Verify_Boot_Count_After_BMC_Reboot 130 131 Set BMC Boot Count ${0} 132 Redfish OBMC Reboot (off) 133 ${boot_count}= Get BMC Boot Count 134 Should Be Equal ${boot_count} ${1} msg=Boot count is not incremented. 135 136 137Redfish BMC Manager GracefulRestart When Host Booted 138 [Documentation] BMC graceful restart when host is running. 139 [Tags] Redfish_BMC_Manager_GracefulRestart_When_Host_Booted 140 141 Redfish OBMC Reboot (run) 142 143 # TODO: Replace OCC state check with redfish property when available. 144 Verify OCC State 145 146 147*** Keywords *** 148 149Test Setup Execution 150 [Documentation] Do test case setup tasks. 151 152 redfish.Login 153 154 155Test Teardown Execution 156 [Documentation] Do the post test teardown. 157 158 FFDC On Test Case Fail 159 redfish.Logout 160