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