blob: d549bbd5c86cadc10d7a34a2f089ebcfccebcabe [file] [log] [blame]
Sridevi Rameshfe52e402020-02-05 00:15:24 -06001*** Settings ***
2
3Documentation Module to test PLDM platform commands.
4
Sridevi Rameshfc3b07f2020-02-27 04:22:24 -06005Library ../lib/pldm_utils.py
6Variables ../data/pldm_variables.py
7Resource ../lib/openbmc_ffdc.robot
8Resource ../lib/bmc_redfish_resource.robot
9Resource ../lib/boot_utils.robot
Sridevi Rameshfe52e402020-02-05 00:15:24 -060010
Sridevi Rameshfc3b07f2020-02-27 04:22:24 -060011Test Setup Printn
12Test Teardown FFDC On Test Case Fail
13Suite Teardown Pldmtool Platform Suite Cleanup
Sridevi Rameshfe52e402020-02-05 00:15:24 -060014
15*** Test Cases ***
Sridevi Rameshfe52e402020-02-05 00:15:24 -060016Verify GetPDR
17 [Documentation] Verify GetPDR (Platform Descpritor Record) response message.
18 [Tags] Verify_GetPDR
Sridevi Rameshfe52e402020-02-05 00:15:24 -060019
Sridevi Ramesh538d18d2020-03-30 11:45:42 -050020 ${record_handle}= Set Variable ${1}
21 # Note: Record handle count is unknown and it is dynamic in nature.
22 # Assuming there are 100 record handle.
23 FOR ${i} IN RANGE 100
24 ${next_record_handle}= Run Keyword Verify GetPDR For Record Handle ${record_handle}
25 Exit For Loop If ${next_record_handle} == 0
26 ${record_handle}= Set Variable ${next_record_handle}
27 END
Sridevi Rameshfe52e402020-02-05 00:15:24 -060028
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -050029
Sridevi Rameshfe52e402020-02-05 00:15:24 -060030Verify SetStateEffecterStates
31 [Documentation] Verify set state effecter states response message.
32 [Tags] Verify_SetStateEffecterStates
33 [Template] Verify SetStateEffecterStates For Effecter States
34
Sridevi Rameshca3223a2020-03-11 03:58:58 -050035 # EffecterHandle Count EffecterStates (effecterID effecterState)
36
Sridevi Ramesh538d18d2020-03-30 11:45:42 -050037 '1' '1' '1 1' # (effecterState -> 1 -> 'Boot Not Active')
38 '1' '1' '1 2' # (effecterState -> 2 -> 'Boot Completed')
39 '2' '1' '1 9' # (effecterState -> 9 -> 'System Power is in soft off mode')
40 '3' '1' '1 6' # (effecterState -> 6 -> 'Graceful Restart Requested')
Sridevi Rameshfe52e402020-02-05 00:15:24 -060041
42*** Keywords ***
43
44Verify GetPDR For Record Handle
Sridevi Ramesh538d18d2020-03-30 11:45:42 -050045 [Documentation] Verify GetPDR (Platform Descpritor Record) for given input
46 ... record handle and return next record handle.
Sridevi Rameshfe52e402020-02-05 00:15:24 -060047 [Arguments] ${record_handle}
48
49 # Description of argument(s):
Sridevi Rameshca3223a2020-03-11 03:58:58 -050050 # ${record_handle} Record handle.
Sridevi Ramesh538d18d2020-03-30 11:45:42 -050051 # e.g. '1' is record handle 'Boot Progress' (196).
52 # '2' is record handle 'System Power State (260)'.
53 # '3' is record handle 'Software Termination Status (129)'.
Sridevi Rameshfe52e402020-02-05 00:15:24 -060054
55 # pldm_output:
56 # [responseCount]: 29
57 # [recordHandle]: 1
58 # [PDRHeaderVersion]: 1
59 # [PDRType]: 11
60 # [recordChangeNumber]: 0
61 # [dataLength]: 19
62 # [PLDMTerminusHandle]: 0
63 # [effecterID]: 1
64 # [entityType]: 33
65 # [entityInstanceNumber]: 0
66 # [containerID]: 0
67 # [effecterSemanticID]: 0
68 # [effecterInit]: 0
69 # [effecterDescriptionPDR]: false
70 # [compositeEffecterCount]: 1
71 # [stateSetID]: 196
72 # [possibleStatesSize]: 1
73 # [possibleStates]: 6
74
75 ${pldm_cmd}= Evaluate $CMD_GETPDR % ${record_handle}
76 ${pldm_output}= Pldmtool ${pldm_cmd}
77 Rprint Vars pldm_output
Sridevi Rameshda95c472020-07-28 06:51:48 -050078
Sridevi Ramesh072d5af2020-06-02 09:20:57 -050079 # Note: Output of GetPDR type 'PLDM_NUMERIC_EFFECTER_PDR' has dynamic content
80 # hence just checking pdrtype only
81 # GetPDR type 'PLDM_STATE_SENSOR_PDR' Dev implementation is still in progress
82 # TODO: Verify output of GetPDR type 'PLDM_STATE_SENSOR_PDR'
Sridevi Rameshda95c472020-07-28 06:51:48 -050083
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -050084 Run Keyword If '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_STATE_EFFECTER_PDR']}'
Sridevi Rameshda95c472020-07-28 06:51:48 -050085 ... Log To Console "Found PDR Type - PLDM_STATE_EFFECTER_PDR"
86
87 ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_PDR_FRU_RECORD_SET']}'
Sridevi Ramesh538d18d2020-03-30 11:45:42 -050088 ... Valid Dict pldm_output valid_values=${RESPONSE_DICT_GETPDR_FRURECORDSETIDENTIFIER}
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -050089
Sridevi Rameshda95c472020-07-28 06:51:48 -050090 ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_PDR_ENTITY_ASSOCIATION']}'
91 ... Valid Dict pldm_output valid_values=${RESPONSE_DICT_GETPDR_PDRENTITYASSOCIATION}
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -050092
Sridevi Rameshda95c472020-07-28 06:51:48 -050093 ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_STATE_SENSOR_PDR']}'
94 ... Valid Dict pldm_output valid_values=${RESPONSE_DICT_GETPDR_STATESENSORPDR}
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -050095
Sridevi Rameshda95c472020-07-28 06:51:48 -050096 ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_NUMERIC_EFFECTER_PDR']}'
97 ... Log To Console "Found PDR Type - PLDM_NUMERIC_EFFECTER_PDR"
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -050098
Sridevi Rameshda95c472020-07-28 06:51:48 -050099 ... ELSE IF '${pldm_output['pdrtype']}' == '${PLDM_PDR_TYPES['PLDM_TERMINUS_LOCATOR_PDR']}'
100 ... Log To Console "Found PDR Type - PLDM_TERMINUS_LOCATOR_PDR"
Sridevi Rameshdfc7fcb2020-07-23 03:03:57 -0500101
Sridevi Rameshda95c472020-07-28 06:51:48 -0500102 ... ELSE Fail msg="Unknown PDR Type is received"
Sridevi Rameshfe52e402020-02-05 00:15:24 -0600103
Sridevi Ramesh538d18d2020-03-30 11:45:42 -0500104 Should be equal as strings ${pldm_output['recordhandle']} ${record_handle}
105 [Return] ${pldm_output['nextrecordhandle']}
Sridevi Rameshfe52e402020-02-05 00:15:24 -0600106
107Verify SetStateEffecterStates For Effecter States
108 [Documentation] Verify set state effecter states for given input effecter states.
Sridevi Rameshca3223a2020-03-11 03:58:58 -0500109 [Arguments] ${effecter_handle} ${count} ${effecter_states}
Sridevi Rameshfe52e402020-02-05 00:15:24 -0600110
111 # Description of argument(s):
Sridevi Rameshca3223a2020-03-11 03:58:58 -0500112 # ${effecter_handle} A handle that is used to identify and access the effecter (e.g. '1').
113 # e.g. '1' is effecter handle 'Boot Progress'.
114 # '2' is effecter handle 'System Power State'.
115 # ${count} The number of individual sets of effecter information (e.g. '1').
116 # ${effecter_states} (effecterID effecterState).
117 # e.g. '1 1'.
Sridevi Rameshfe52e402020-02-05 00:15:24 -0600118
119 # Example output:
Sridevi Ramesh072d5af2020-06-02 09:20:57 -0500120 # [SetStateEffecterStates ]: SUCCESS
Sridevi Rameshfe52e402020-02-05 00:15:24 -0600121
Sridevi Rameshca3223a2020-03-11 03:58:58 -0500122 ${pldm_cmd}= Evaluate $CMD_SETSTATEEFFECTERSTATES % (${effecter_handle}, ${count}, ${effecter_states})
Sridevi Rameshfe52e402020-02-05 00:15:24 -0600123 ${pldm_output}= Pldmtool ${pldm_cmd}
124 Rprint Vars pldm_output
125 Valid Value pldm_output['setstateeffecterstates'] ['SUCCESS']
Sridevi Rameshfc3b07f2020-02-27 04:22:24 -0600126
Sridevi Rameshfc3b07f2020-02-27 04:22:24 -0600127Pldmtool Platform Suite Cleanup
128 [Documentation] Reset BMC at suite cleanup.
129
George Keishing64fdf622020-06-18 02:49:38 -0500130 Redfish.Login
Sridevi Ramesh88f21722020-04-16 05:54:02 -0500131 Redfish Hard Power Off
Sridevi Ramesh072d5af2020-06-02 09:20:57 -0500132 Redfish Power On
George Keishing64fdf622020-06-18 02:49:38 -0500133 Redfish.Logout