| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 1 | *** Settings *** | 
|  | 2 |  | 
|  | 3 | Documentation    Module to test PLDM BIOS commands. | 
|  | 4 |  | 
|  | 5 | Library          Collections | 
|  | 6 | Library          String | 
|  | 7 | Library          ../lib/pldm_utils.py | 
|  | 8 | Variables        ../data/pldm_variables.py | 
|  | 9 | Resource         ../lib/openbmc_ffdc.robot | 
|  | 10 |  | 
|  | 11 | Test Setup       Printn | 
|  | 12 | Test Teardown    FFDC On Test Case Fail | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 13 | Suite Setup      PLDM BIOS Suite Setup | 
| George Keishing | e18030c | 2022-07-20 13:37:01 -0500 | [diff] [blame] | 14 | Suite Teardown   Run Keyword And Ignore Error  PLDM BIOS Suite Cleanup | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 15 |  | 
|  | 16 | *** Test Cases *** | 
|  | 17 |  | 
|  | 18 | Verify GetDateTime | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 19 | [Documentation]  Verify host date & time. | 
|  | 20 | [Tags]  Verify_GetDateTime | 
|  | 21 |  | 
|  | 22 | # Example output: | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 23 | # { | 
|  | 24 | #     "Response": "2020-11-07 07:10:10" | 
|  | 25 | # } | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 26 |  | 
|  | 27 | ${pldm_output}=  Pldmtool  bios GetDateTime | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 28 | @{date_time}=  Split String  ${pldm_output['Response']}  ${SPACE} | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 29 | @{time}=  Split String  ${date_time}[1]  : | 
|  | 30 |  | 
| George Keishing | 2e56ad9 | 2022-10-12 11:39:54 -0500 | [diff] [blame] | 31 | ${bmc_date}=  Get Current Date from BMC | 
|  | 32 | # Date format example: 2022-10-12 16:31:17 | 
|  | 33 | Log To Console  BMC Date: ${bmc_date} | 
|  | 34 | # Example : ['2022-10-12', '16:31:17'] | 
|  | 35 | @{current_time}=  Split String  ${bmc_date}  ${EMPTY} | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 36 |  | 
| George Keishing | 2e56ad9 | 2022-10-12 11:39:54 -0500 | [diff] [blame] | 37 | # verify date matching pldmtool vs BMC current time. | 
|  | 38 | Should Contain  ${current_time}  ${date_time[0]} | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 39 |  | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 40 |  | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 41 | Verify SetDateTime | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 42 | [Documentation]  Verify set date & time for the host. | 
|  | 43 | [Tags]  Verify_SetDateTime | 
|  | 44 |  | 
|  | 45 | # Example output: | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 46 | # { | 
|  | 47 | #     "Response": "SUCCESS" | 
|  | 48 | # } | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 49 |  | 
|  | 50 | ${current_date_time}=  Get Current Date  UTC  exclude_millis=True | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 51 | # Example output: | 
|  | 52 | # 2020-11-25 07:34:30 | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 53 |  | 
|  | 54 | ${date}=  Add Time To Date  ${current_date_time}  400 days  exclude_millis=True | 
|  | 55 | ${upgrade_date}=  Evaluate  re.sub(r'-* *:*', "", '${date}')  modules=re | 
|  | 56 |  | 
|  | 57 | ${time}=  Add Time To Date  ${current_date_time}  01:01:00  exclude_millis=True | 
|  | 58 | ${upgrade_time}=  Evaluate  re.sub(r'-* *:*', "", '${time}')  modules=re | 
|  | 59 |  | 
|  | 60 | # Set date. | 
|  | 61 | ${cmd_set_date}=  Evaluate  $CMD_SETDATETIME % '${upgrade_date}' | 
|  | 62 | ${pldm_output}=  Pldmtool  ${cmd_set_date} | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 63 | Valid Value  pldm_output['Response']  ['SUCCESS'] | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 64 |  | 
|  | 65 | # Set time. | 
|  | 66 | ${cmd_set_time}=  Evaluate  $CMD_SETDATETIME % '${upgrade_time}' | 
|  | 67 | ${pldm_output}=  Pldmtool  ${cmd_set_time} | 
| Sridevi Ramesh | fe52e40 | 2020-02-05 00:15:24 -0600 | [diff] [blame] | 68 |  | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 69 |  | 
| Sridevi Ramesh | f60581b | 2020-04-07 05:11:12 -0500 | [diff] [blame] | 70 | Verify GetBIOSTable For AttributeValueTable | 
|  | 71 | [Documentation]  Verify if attribute value table content exist for | 
|  | 72 | ...              GetBIOSTable with table type attribute value table. | 
|  | 73 | [Tags]  Verify_GetBIOSTable_For_AttributeValueTable | 
|  | 74 |  | 
|  | 75 | # Example pldm_output: | 
|  | 76 | # [pldm_attributevaluetable]:                     True | 
|  | 77 | # [attributehandle]:                              0 | 
|  | 78 | # [     attributetype]:                           BIOSStringReadOnly | 
|  | 79 | # [     currentstringlength]:                     15 | 
| Sridevi Ramesh | f60581b | 2020-04-07 05:11:12 -0500 | [diff] [blame] | 80 |  | 
| George Keishing | f924895 | 2021-05-28 07:52:37 -0500 | [diff] [blame] | 81 | ${count}=  Get Length  ${attr_table_data} | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 82 | ${attr_val_list}=  Create List | 
|  | 83 | FOR  ${i}  IN RANGE  ${count} | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 84 | Append To List  ${attr_val_list}  ${attr_table_data}[${i}][AttributeType] | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 85 | END | 
|  | 86 | Valid List  attr_val_list  required_values=${RESPONSE_LIST_GETBIOSTABLE_ATTRVALTABLE} | 
| Sridevi Ramesh | fe52e40 | 2020-02-05 00:15:24 -0600 | [diff] [blame] | 87 |  | 
| Sridevi Ramesh | 5753745 | 2021-01-18 03:25:05 -0600 | [diff] [blame] | 88 |  | 
| Sridevi Ramesh | 5753745 | 2021-01-18 03:25:05 -0600 | [diff] [blame] | 89 | Verify GetBIOSAttributeCurrentValueByHandle | 
| Sridevi Ramesh | 5753745 | 2021-01-18 03:25:05 -0600 | [diff] [blame] | 90 | [Documentation]  Verify GetBIOSAttributeCurrentValueByHandle with the | 
|  | 91 | ...              various BIOS attribute handle and its values. | 
|  | 92 | [Tags]  Verify_GetBIOSAttributeCurrentValueByHandle | 
|  | 93 |  | 
|  | 94 | # Example output: | 
|  | 95 | # | 
|  | 96 | # pldmtool bios GetBIOSAttributeCurrentValueByHandle -a pvm_fw_boot_side | 
|  | 97 | # { | 
|  | 98 | #     "CurrentValue": "Temp" | 
|  | 99 | # } | 
|  | 100 |  | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 101 | ${attr_val_data}=  GetBIOSEnumAttributeOptionalValues  ${attr_table_data} | 
| Sridevi Ramesh | 5753745 | 2021-01-18 03:25:05 -0600 | [diff] [blame] | 102 | @{attr_handles}=  Get Dictionary Keys  ${attr_val_data} | 
|  | 103 | FOR  ${i}  IN  @{attr_handles} | 
|  | 104 | ${cur_attr}=  Pldmtool  bios GetBIOSAttributeCurrentValueByHandle -a ${i} | 
|  | 105 | @{attr_val_list}=  Set Variable  ${attr_val_data}[${i}] | 
|  | 106 | Run Keyword If  '${cur_attr['CurrentValue']}' not in @{attr_val_list} | 
|  | 107 | ...  Fail  Invalid GetBIOSAttributeCurrentValueByHandle value found. | 
|  | 108 | END | 
|  | 109 |  | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 110 |  | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 111 | *** Keywords *** | 
|  | 112 |  | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 113 | PLDM BIOS Suite Setup | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 114 | [Documentation]  Perform PLDM BIOS suite setup. | 
|  | 115 |  | 
|  | 116 | ${pldm_output}=  Pldmtool  bios GetBIOSTable --type AttributeTable | 
|  | 117 | Set Global Variable  ${attr_table_data}  ${pldm_output} | 
|  | 118 |  | 
| George Keishing | 1d14970 | 2022-09-20 01:53:38 -0500 | [diff] [blame] | 119 | Set Time To Manual Mode | 
|  | 120 |  | 
|  | 121 | Sleep  10s | 
|  | 122 |  | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 123 |  | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 124 | PLDM BIOS Suite Cleanup | 
| Sridevi Ramesh | 2ab3d38 | 2021-03-29 04:16:01 -0500 | [diff] [blame] | 125 | [Documentation]  Perform PLDM BIOS suite cleanup. | 
| Sridevi Ramesh | 1495bc4 | 2020-02-04 03:13:33 -0600 | [diff] [blame] | 126 |  | 
|  | 127 | ${result}=  Get Current Date  UTC  exclude_millis=True | 
|  | 128 | ${current_date_time}=  Evaluate  re.sub(r'-* *:*', "", '${result}')  modules=re | 
|  | 129 | ${cmd_set_date_time}=  Evaluate  $CMD_SETDATETIME % '${current_date_time}' | 
|  | 130 | ${pldm_output}=  Pldmtool  ${cmd_set_date_time} | 
| Sridevi Ramesh | 961050b | 2020-11-12 11:04:30 -0600 | [diff] [blame] | 131 | Valid Value  pldm_output['Response']  ['SUCCESS'] | 
| George Keishing | 1d14970 | 2022-09-20 01:53:38 -0500 | [diff] [blame] | 132 |  | 
|  | 133 |  | 
|  | 134 | Set Time To Manual Mode | 
|  | 135 | [Documentation]  Set date time to manual mode via Redfish. | 
|  | 136 |  | 
| George Keishing | a92a2e1 | 2022-09-20 02:12:42 -0500 | [diff] [blame] | 137 | Redfish.Login | 
| George Keishing | 1d14970 | 2022-09-20 01:53:38 -0500 | [diff] [blame] | 138 | Redfish.Patch  ${REDFISH_NW_PROTOCOL_URI}  body={'NTP':{'ProtocolEnabled': ${False}}} | 
|  | 139 | ...  valid_status_codes=[${HTTP_OK}, ${HTTP_NO_CONTENT}] | 
| George Keishing | 2e56ad9 | 2022-10-12 11:39:54 -0500 | [diff] [blame] | 140 |  | 
|  | 141 |  | 
|  | 142 | Get Current Date from BMC | 
|  | 143 | [Documentation]  Runs the date command from BMC and returns current date and time. | 
|  | 144 |  | 
|  | 145 | # Get Current Date from BMC. | 
|  | 146 | ${date}  ${stderr}  ${rc}=  BMC Execute Command   date | 
|  | 147 |  | 
|  | 148 | # Split the string and remove first and 2nd last value from the list and | 
|  | 149 | # join to form %d %b %H:%M:%S %Y date format | 
|  | 150 | ${date}=  Split String  ${date} | 
|  | 151 | Remove From List  ${date}  0 | 
|  | 152 | Remove From List  ${date}  -2 | 
|  | 153 | ${date}=  Evaluate  " ".join(${date}) | 
|  | 154 |  | 
|  | 155 | # Convert the date format to %Y/%m/%d %H:%M:%S | 
|  | 156 | ${date}=  Convert Date  ${date}  date_format=%b %d %H:%M:%S %Y | 
|  | 157 | ...  result_format=%Y-%m-%d %H:%M:%S  exclude_millis=True | 
|  | 158 |  | 
|  | 159 | [Return]   ${date} |