| *** Settings *** |
| |
| Documentation Module to test PLDM platform commands. |
| |
| Library ../lib/pldm_utils.py |
| Variables ../data/pldm_variables.py |
| Resource ../lib/openbmc_ffdc.robot |
| Resource ../lib/bmc_redfish_resource.robot |
| Resource ../lib/boot_utils.robot |
| |
| Test Setup Printn |
| Test Teardown FFDC On Test Case Fail |
| Suite Teardown Pldmtool Platform Suite Cleanup |
| |
| *** Test Cases *** |
| Verify GetPDR |
| [Documentation] Verify GetPDR (Platform Descpritor Record) response message. |
| [Tags] Verify_GetPDR |
| |
| ${record_handle}= Set Variable ${1} |
| # Note: Record handle count is unknown and it is dynamic in nature. |
| # Assuming there are 100 record handle. |
| FOR ${i} IN RANGE 100 |
| ${next_record_handle}= Run Keyword Verify GetPDR For Record Handle ${record_handle} |
| Exit For Loop If ${next_record_handle} == 0 |
| ${record_handle}= Set Variable ${next_record_handle} |
| END |
| |
| |
| Verify SetStateEffecterStates |
| [Documentation] Verify set state effecter states response message. |
| [Tags] Verify_SetStateEffecterStates |
| [Template] Verify SetStateEffecterStates For Effecter States |
| |
| # EffecterHandle Count EffecterStates (effecterID effecterState) |
| |
| '1' '1' '1 1' # (effecterState -> 1 -> 'Boot Not Active') |
| '1' '1' '1 2' # (effecterState -> 2 -> 'Boot Completed') |
| '2' '1' '1 9' # (effecterState -> 9 -> 'System Power is in soft off mode') |
| '3' '1' '1 6' # (effecterState -> 6 -> 'Graceful Restart Requested') |
| |
| *** Keywords *** |
| |
| Verify GetPDR For Record Handle |
| [Documentation] Verify GetPDR (Platform Descpritor Record) for given input |
| ... record handle and return next record handle. |
| [Arguments] ${record_handle} |
| |
| # Description of argument(s): |
| # ${record_handle} Record handle. |
| # e.g. '1' is record handle 'Boot Progress' (196). |
| # '2' is record handle 'System Power State (260)'. |
| # '3' is record handle 'Software Termination Status (129)'. |
| |
| # pldm_output: |
| # [responseCount]: 29 |
| # [recordHandle]: 1 |
| # [PDRHeaderVersion]: 1 |
| # [PDRType]: 11 |
| # [recordChangeNumber]: 0 |
| # [dataLength]: 19 |
| # [PLDMTerminusHandle]: 0 |
| # [effecterID]: 1 |
| # [entityType]: 33 |
| # [entityInstanceNumber]: 0 |
| # [containerID]: 0 |
| # [effecterSemanticID]: 0 |
| # [effecterInit]: 0 |
| # [effecterDescriptionPDR]: false |
| # [compositeEffecterCount]: 1 |
| # [stateSetID]: 196 |
| # [possibleStatesSize]: 1 |
| # [possibleStates]: 6 |
| |
| ${pldm_cmd}= Evaluate $CMD_GETPDR % ${record_handle} |
| ${pldm_output}= Pldmtool ${pldm_cmd} |
| Rprint Vars pldm_output |
| # Note: Output of GetPDR type 'PLDM_NUMERIC_EFFECTER_PDR' has dynamic content |
| # hence just checking pdrtype only |
| # GetPDR type 'PLDM_STATE_SENSOR_PDR' Dev implementation is still in progress |
| # TODO: Verify output of GetPDR type 'PLDM_STATE_SENSOR_PDR' |
| Run Keyword If '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_STATE_EFFECTER_PDR']}' |
| ... Run Keywords Log To Console "Found PDR Type - PLDM_STATE_EFFECTER_PDR" AND |
| ... Valid Dict pldm_output valid_values=${RESPONSE_DICT_GETPDR_FRURECORDSETIDENTIFIER} |
| |
| ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_PDR_ENTITY_ASSOCIATION']}' |
| ... Valid Dict pldm_output valid_values=${RESPONSE_DICT_GETPDR_PDRENTITYASSOCIATION} |
| |
| ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_STATE_SENSOR_PDR']}' |
| ... Valid Dict pldm_output valid_values=${RESPONSE_DICT_GETPDR_STATESENSORPDR} |
| |
| ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_NUMERIC_EFFECTER_PDR']}' |
| ... Log To Console "Found PDR Type - PLDM_NUMERIC_EFFECTER_PDR" |
| |
| ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_TERMINUS_LOCATOR_PDR']}' |
| ... Log To Console "Found PDR Type - PLDM_TERMINUS_LOCATOR_PDR" |
| |
| ... ELSE Fail msg="Unknown PDR Type is received" |
| |
| Should be equal as strings ${pldm_output['recordhandle']} ${record_handle} |
| [Return] ${pldm_output['nextrecordhandle']} |
| |
| Verify SetStateEffecterStates For Effecter States |
| [Documentation] Verify set state effecter states for given input effecter states. |
| [Arguments] ${effecter_handle} ${count} ${effecter_states} |
| |
| # Description of argument(s): |
| # ${effecter_handle} A handle that is used to identify and access the effecter (e.g. '1'). |
| # e.g. '1' is effecter handle 'Boot Progress'. |
| # '2' is effecter handle 'System Power State'. |
| # ${count} The number of individual sets of effecter information (e.g. '1'). |
| # ${effecter_states} (effecterID effecterState). |
| # e.g. '1 1'. |
| |
| # Example output: |
| # [SetStateEffecterStates ]: SUCCESS |
| |
| ${pldm_cmd}= Evaluate $CMD_SETSTATEEFFECTERSTATES % (${effecter_handle}, ${count}, ${effecter_states}) |
| ${pldm_output}= Pldmtool ${pldm_cmd} |
| Rprint Vars pldm_output |
| Valid Value pldm_output['setstateeffecterstates'] ['SUCCESS'] |
| |
| Pldmtool Platform Suite Cleanup |
| [Documentation] Reset BMC at suite cleanup. |
| |
| Redfish.Login |
| Redfish Hard Power Off |
| Redfish Power On |
| Redfish.Logout |