1*** Settings *** 2 3Documentation Module to test dcmi get temperature reading functionality. 4Resource ../../lib/ipmi_client.robot 5Resource ../../lib/openbmc_ffdc.robot 6Resource ../../lib/bmc_network_utils.robot 7Resource ../../lib/boot_utils.robot 8Variables ../../data/ipmi_raw_cmd_table.py 9Variables ../../data/dcmi_raw_cmd_table.py 10Variables ../../data/ipmi_variable.py 11Library ../../lib/bmc_network_utils.py 12Library ../../lib/ipmi_utils.py 13Library ../../lib/utilities.py 14Library JSONLibrary 15 16Suite Setup Suite Setup Execution 17 18Test Tags DCMI_Get_Temperature_Reading 19 20*** Variables *** 21 22${config_file_name} dcmi_sensors.json 23${dcmi_sensors_info_json_file} /usr/share/ipmi-providers/${config_file_name} 24${client_config_file_path} ${EXEC_DIR}/${config_file_name} 25&{dcmi_sensor_uri} 26 27*** Test Cases *** 28Verify Get Temperature Reading Command For Inlet Temperature Sensor 29 [Documentation] Verify IPMI Get Temperature Reading command for inlet temperature sensor. 30 [Tags] Verify_Get_Temperature_Reading_Command_For_Inlet_Temperature_Sensor 31 32 ${cmd}= Catenate ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][0]} 33 ... ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][1]} 0x00 0x00 34 ${ipmi_resp}= Run IPMI Command ${cmd} 35 Verify Reading With IPMI ${ipmi_resp} ${1} inlet 36 # Verify Temperature Reading With Dbus URI ${ipmi_resp} inlet ${1} 37 38Verify Get Temperature Reading Command For CPU 0 Temperature Sensor 39 [Documentation] Verify IPMI Get Temperature Reading command for cpu0 temperature sensor. 40 [Tags] Verify_Get_Temperature_Reading_Command_For_CPU_0_Temperature_Sensor 41 42 ${cmd}= Catenate ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][0]} 43 ... ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][2]} 0x00 0x00 44 ${ipmi_resp}= Run IPMI Command ${cmd} 45 Verify Reading With IPMI ${ipmi_resp} ${1} cpu 46 # Verify Temperature Reading With Dbus URI ${ipmi_resp} cpu ${1} 47 48Verify Get Temperature Reading Command For CPU 1 Temperature Sensor 49 [Documentation] Verify IPMI Get Temperature Reading command for cpu1 temperature sensor. 50 [Tags] Verify_Get_Temperature_Reading_Command_For_CPU_1_Temperature_Sensor 51 52 ${cmd}= Catenate ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][0]} 53 ... ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][2]} 0x00 0x00 54 ${ipmi_resp}= Run IPMI Command ${cmd} 55 Verify Reading With IPMI ${ipmi_resp} ${2} cpu 56 # Verify Temperature Reading With Dbus URI ${ipmi_resp} cpu ${2} 57 58Verify Get Temperature Reading Command For Baseboard Temperature Sensor 59 [Documentation] Verify IPMI Get Temperature Reading command for baseboard temperature sensor. 60 [Tags] Verify_Get_Temperature_Reading_Command_For_Baseboard_Temperature_Sensor 61 62 ${cmd}= Catenate ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][0]} 63 ... ${DCMI_RAW_CMD['DCMI']['GET_TEMPERATURE_READING'][3]} 0x00 0x00 64 ${ipmi_resp}= Run IPMI Command ${cmd} 65 Verify Reading With IPMI ${ipmi_resp} ${1} baseboard 66 # Verify Temperature Reading With Dbus URI ${ipmi_resp} baseboard ${1} 67 68*** Keywords *** 69Suite Setup Execution 70 [Documentation] Get dcmi sensors uri from config file. 71 72 IPMI Power On stack_mode=skip quiet=1 73 74 # Get this file to client machine /usr/share/ipmi-providers/dcmi_sensors.json 75 scp.Open Connection 76 ... ${OPENBMC_HOST} username=${OPENBMC_USERNAME} password=${OPENBMC_PASSWORD} port=${SSH_PORT} 77 scp.Get File ${dcmi_sensors_info_json_file} ${EXEC_DIR} 78 scp.Close Connection 79 80 ${config_file}= OperatingSystem.Get File ${client_config_file_path} 81 ${config_file_response}= Evaluate json.loads('''${config_file}''') json 82 83 ${remove_configuration_file}= Catenate rm -rf ${client_config_file_path} 84 ${rc} ${output}= Shell Cmd ${remove_configuration_file} 85 86 FOR ${key} ${value} IN &{config_file_response} 87 &{tmp}= Create Dictionary 88 FOR ${response} IN @{value} 89 ${sensor_dbus}= Get From Dictionary ${response} dbus 90 ${instance}= Get From Dictionary ${response} instance 91 Set To Dictionary ${tmp} ${instance} ${sensor_dbus} 92 END 93 Set To Dictionary ${dcmi_sensor_uri} ${key} ${tmp} 94 END 95 96Verify Temperature Reading With Dbus URI 97 [Documentation] Verify temperature from ipmi response and json file. 98 [Arguments] ${ipmi_resp} ${key} ${instance} 99 100 # Description of argument(s): 101 # ipmi_resp IPMI command response. 102 # key Entity ID description i.e inlet, cpu, baseboard. 103 # instance instance number 1, 2, .. 104 105 ${dbus_uris}= Get From Dictionary ${dcmi_sensor_uri} ${key} 106 ${dbus_uri}= Get From Dictionary ${dbus_uris} ${instance} 107 108 ${get_reading_value}= Set Variable If 109 ... '${instance}' == '1' ${3} 110 ... '${instance}' == '2' ${5} 111 112 ${ipmi_resp_list}= Split String ${ipmi_resp} 113 ${temperature_reading}= Get From List ${ipmi_resp_list} ${get_reading_value} 114 ${temp_reading}= Convert To Integer ${temperature_reading} 16 115 ${busctl_cmd}= Catenate busctl introspect xyz.openbmc_project.HwmonTempSensor ${dbus_uri} 116 ${busctl_cmd_resp}= BMC Execute Command ${busctl_cmd} 117 ${current_temp_value_from_dbus}= Get Regexp Matches ${busctl_cmd_resp[0]} 118 ... \\.Value\\s+property\\s+d\\s+(\\S+)\\s 1 119 120 ${min_value}= Evaluate ${temp_reading} - 1 121 ${max_value}= Evaluate ${temp_reading} + 1 122 123Check Reading Value In D-Bus 124 [Documentation] Verify temperature from ipmi response and json file. 125 [Arguments] ${key} ${instance} ${dcmi_reading_value} 126 127 # Description of argument(s): 128 # key Entity ID description i.e inlet, cpu, baseboard. 129 # instance instance number 1, 2, .. 130 131 ${dbus_uris}= Get From Dictionary ${dcmi_sensor_uri} ${key} 132 ${dbus_uri}= Get From Dictionary ${dbus_uris} ${instance} 133 134 ${busctl_cmd}= Catenate busctl introspect xyz.openbmc_project.HwmonTempSensor ${dbus_uri} 135 ${busctl_cmd_resp}= BMC Execute Command ${busctl_cmd} 136 ${current_temp_value_from_dbus}= Get Regexp Matches ${busctl_cmd_resp[0]} 137 ... \\.Value\\s+property\\s+d\\s+(\\S+)\\s 1 138 139 IF '${current_temp_value_from_dbus[0]}' == 'nan' and '${dcmi_reading_value}' == '0' 140 Fail msg=sensor reading value is not present. 141 END 142 143 IF '${current_temp_value_from_dbus[0]}' != 'nan' and '${dcmi_reading_value}' == '0' 144 Fail msg=sensor reading value is showing as 0 in dcmi get temperature raw command. 145 END 146 147 ${dbus_reading_value}= Set Variable .${current_temp_value_from_dbus[0].split(".")[1].strip()} 148 ${status}= Run Keyword And Return Status Should Be True ${dbus_reading_value} > .499 149 150 IF ${status} == False 151 Fail msg=sensor reading value is showing wrongly in dcmi get temperature raw command. 152 END 153 154 ${dbus_reading_value}= Set Variable ${current_temp_value_from_dbus[0].split(".")[0].strip()} 155 Should Be Equal ${dcmi_reading_value} ${dbus_reading_value} 156 ... msg=sensor reading value is showing wrongly in dcmi get temperature raw command. 157 158Verify Reading With IPMI 159 [Documentation] Verify temperature reading with ipmi command. 160 [Arguments] ${ipmi_resp} ${instance} ${key} 161 162 # Description of argument(s): 163 # ipmi_resp IPMI command response. 164 # instance instance number 1, 2, .. 165 # key Entity ID description i.e inlet, cpu, baseboard. 166 167 ${get_reading_value}= Set Variable If 168 ... '${instance}' == '1' ${3} 169 ... '${instance}' == '2' ${5} 170 171 ${ipmi_resp_list}= Split String ${ipmi_resp} 172 ${temperature_reading}= Get From List ${ipmi_resp_list} ${get_reading_value} 173 ${dcmi_reading}= Convert To Integer ${temperature_reading} 16 174 IF '${dcmi_reading}' == '0' 175 Check Reading Value In D-Bus ${key} ${instance} ${dcmi_reading} 176 END 177 ${dcmi_temp_reading}= Convert To String ${dcmi_reading} 178 ${ipmi_sensor_cmd_resp}= Get IPMI Sensor Reading ${key} ${instance} 179 ${ipmi_sensor_cmd_resp_list}= Split String ${ipmi_sensor_cmd_resp} | 180 ${ipmi_temp_reading}= Set Variable ${ipmi_sensor_cmd_resp_list[1].strip().split(".")[0]} 181 ${reading_status}= Run Keyword And Return Status Should Be Equal 182 ... ${dcmi_temp_reading} ${ipmi_temp_reading} 183 IF ${reading_status} == False 184 Check Reading Value In D-Bus ${key} ${instance} ${dcmi_temp_reading} 185 END 186 187Get IPMI Sensor Reading 188 [Documentation] Return ipmi sensor reading. 189 [Arguments] ${key} ${instance} 190 191 # Description of argument(s): 192 # instance Entity ID description i.e inlet, cpu, baseboard. 193 # index Selecting the corresponding sensor dbus uri from list. 194 195 ${dbus_uris}= Get From Dictionary ${dcmi_sensor_uri} ${key} 196 ${dbus_uri}= Get From Dictionary ${dbus_uris} ${instance} 197 ${sensor_name}= Set Variable ${dbus_uri.split('/')[-1]} 198 199 ${sensor_format}= Run IPMI Standard Command sensor 200 ${sensor_name_status}= Run Keyword And Return Status Should Contain 201 ... ${sensor_format} _ 202 203 ${replaced_str}= Replace String ${sensor_name} _ ${SPACE} 204 ${sensor_name}= Set Variable If ${sensor_name_status} == True 205 ... ${sensor_name_dbus} 206 ... ${replaced_str} 207 208 ${ret}= Run External IPMI Standard Command sensor | grep -i "${sensor_name}" 209 210 RETURN ${ret} 211