| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 1 | *** Settings *** | 
|  | 2 | Documentation    Error logging utility keywords. | 
|  | 3 |  | 
|  | 4 | Resource        rest_client.robot | 
| George Keishing | a6c0089 | 2021-10-11 01:09:54 -0500 | [diff] [blame] | 5 | Resource        bmc_redfish_utils.robot | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 6 | Variables       ../data/variables.py | 
| Rahul Maheshwari | b8580dd | 2021-05-10 00:57:33 -0500 | [diff] [blame] | 7 | Variables       ../data/pel_variables.py | 
| Michael Walsh | db1adf4 | 2020-03-20 15:05:46 -0500 | [diff] [blame] | 8 |  | 
|  | 9 | *** Variables *** | 
|  | 10 |  | 
|  | 11 |  | 
|  | 12 | # Define variables for use by callers of 'Get Error Logs'. | 
| George Keishing | a80d8ac | 2024-01-13 01:15:14 +0530 | [diff] [blame] | 13 | # Old regex: ${low_severity_errlog_regex}  \\.(Informational|Notice|Debug|OK)$ | 
|  | 14 | # Simplified regex string search | 
|  | 15 | ${low_severity_errlog_regex}   Informational|Notice|Debug|OK | 
| Michael Walsh | db1adf4 | 2020-03-20 15:05:46 -0500 | [diff] [blame] | 16 | &{low_severity_errlog_filter}  Severity=${low_severity_errlog_regex} | 
|  | 17 | &{low_severity_errlog_filter_args}  filter_dict=${low_severity_errlog_filter}  regex=${True}  invert=${True} | 
|  | 18 | # The following is equivalent to &{low_severity_errlog_filter_args} but the name may be more intuitive for | 
|  | 19 | # users. Example usage: | 
|  | 20 | # ${err_logs}=  Get Error Logs  &{filter_low_severity_errlogs} | 
|  | 21 | &{filter_low_severity_errlogs}  &{low_severity_errlog_filter_args} | 
|  | 22 |  | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 23 | *** Keywords *** | 
|  | 24 |  | 
| George Keishing | ba74644 | 2023-03-07 11:51:39 +0530 | [diff] [blame] | 25 | Filter Expected Logging Events | 
|  | 26 | [Documentation]  Get redfish logging entry, remove the user input expected | 
|  | 27 | ...              log event and return the object list. | 
|  | 28 | [Arguments]  ${expected_event}=None | 
|  | 29 |  | 
|  | 30 | # Description of argument(s): | 
|  | 31 | # expected_eventd   Event log list. | 
|  | 32 |  | 
|  | 33 | ${all_event_list}=  Get Redfish Event Logs | 
|  | 34 | Remove Values From List  ${all_event_list}  ${expected_event} | 
|  | 35 |  | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 36 | RETURN  ${all_event_list} | 
| George Keishing | ba74644 | 2023-03-07 11:51:39 +0530 | [diff] [blame] | 37 |  | 
|  | 38 |  | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 39 | Get Logging Entry List | 
|  | 40 | [Documentation]  Get logging entry and return the object list. | 
|  | 41 |  | 
|  | 42 | ${entry_list}=  Create List | 
|  | 43 | ${resp}=  OpenBMC Get Request  ${BMC_LOGGING_ENTRY}list  quiet=${1} | 
|  | 44 | Return From Keyword If  ${resp.status_code} == ${HTTP_NOT_FOUND} | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 45 |  | 
| George Keishing | fbd6700 | 2022-08-01 11:24:03 -0500 | [diff] [blame] | 46 | FOR  ${entry}  IN  @{resp.json()["data"]} | 
| Marissa Garza | 20ccfc7 | 2020-06-19 12:51:10 -0500 | [diff] [blame] | 47 | Continue For Loop If  '${entry.rsplit('/', 1)[1]}' == 'callout' | 
|  | 48 | Append To List  ${entry_list}  ${entry} | 
|  | 49 | END | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 50 |  | 
|  | 51 | # Logging entries list. | 
|  | 52 | # ['/xyz/openbmc_project/logging/entry/14', | 
|  | 53 | #  '/xyz/openbmc_project/logging/entry/15'] | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 54 | RETURN  ${entry_list} | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 55 |  | 
|  | 56 |  | 
|  | 57 | Logging Entry Should Exist | 
|  | 58 | [Documentation]  Find the matching message id and return the entry id. | 
|  | 59 | [Arguments]  ${message_id} | 
|  | 60 |  | 
|  | 61 | # Description of argument(s): | 
|  | 62 | # message_id    Logging message string. | 
|  | 63 | #               Example: "xyz.openbmc_project.Common.Error.InternalFailure" | 
|  | 64 |  | 
| George Keishing | 5ac6e17 | 2018-04-09 12:44:15 -0500 | [diff] [blame] | 65 | @{elog_entries}=  Get Logging Entry List | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 66 |  | 
| Marissa Garza | 20ccfc7 | 2020-06-19 12:51:10 -0500 | [diff] [blame] | 67 | FOR  ${entry}  IN  @{elog_entries} | 
|  | 68 | ${resp}=  Read Properties  ${entry} | 
|  | 69 | ${status}=  Run Keyword And Return Status | 
|  | 70 | ...  Should Be Equal As Strings  ${message_id}  ${resp["Message"]} | 
|  | 71 | Return From Keyword If  ${status} == ${TRUE}  ${entry} | 
|  | 72 | END | 
| George Keishing | c37fca6 | 2017-11-24 05:07:32 -0600 | [diff] [blame] | 73 |  | 
|  | 74 | Fail  No ${message_id} logging entry found. | 
|  | 75 |  | 
| Steven Sombar | 9567294 | 2018-03-23 11:24:58 -0500 | [diff] [blame] | 76 |  | 
|  | 77 | Get Error Logs | 
| Michael Walsh | db1adf4 | 2020-03-20 15:05:46 -0500 | [diff] [blame] | 78 | [Documentation]  Return the BMC error logs as a dictionary. | 
|  | 79 | [Arguments]   ${quiet}=1  &{filter_struct_args} | 
|  | 80 |  | 
|  | 81 | # Example of call using pre-defined filter args (defined above). | 
|  | 82 |  | 
|  | 83 | # ${err_logs}=  Get Error Logs  &{filter_low_severity_errlogs} | 
|  | 84 |  | 
|  | 85 | # In this example, all error logs with "Severity" fields that are neither Informational, Debug nor | 
|  | 86 | # Notice will be returned. | 
| Steven Sombar | 9567294 | 2018-03-23 11:24:58 -0500 | [diff] [blame] | 87 |  | 
|  | 88 | # Description of argument(s): | 
| Michael Walsh | db1adf4 | 2020-03-20 15:05:46 -0500 | [diff] [blame] | 89 | # quiet                         Indicates whether this keyword should run without any output to the | 
|  | 90 | #                               console, 0 = verbose, 1 = quiet. | 
|  | 91 | # filter_struct_args            filter_struct args (e.g. filter_dict, regex, etc.) to be passed directly | 
|  | 92 | #                               to the Filter Struct keyword.  See its prolog for details. | 
| Steven Sombar | 9567294 | 2018-03-23 11:24:58 -0500 | [diff] [blame] | 93 |  | 
|  | 94 | #  The length of the returned dictionary indicates how many logs there are. | 
| Michael Walsh | db1adf4 | 2020-03-20 15:05:46 -0500 | [diff] [blame] | 95 |  | 
|  | 96 | # Use 'Print Error Logs' to print.  Example: | 
|  | 97 |  | 
|  | 98 | # Print Error Logs  ${error_logs}  Message. | 
| Steven Sombar | 9567294 | 2018-03-23 11:24:58 -0500 | [diff] [blame] | 99 |  | 
|  | 100 | ${status}  ${error_logs}=  Run Keyword And Ignore Error  Read Properties | 
| Michael Walsh | db1adf4 | 2020-03-20 15:05:46 -0500 | [diff] [blame] | 101 | ...  /xyz/openbmc_project/logging/entry/enumerate  timeout=30  quiet=${quiet} | 
|  | 102 | Return From Keyword If  '${status}' == 'FAIL'  &{EMPTY} | 
|  | 103 | ${num_filter_struct_args}=  Get Length  ${filter_struct_args} | 
|  | 104 | Return From Keyword If  '${num_filter_struct_args}' == '${0}'  ${error_logs} | 
|  | 105 | ${filtered_error_logs}=  Filter Struct  ${error_logs}  &{filter_struct_args} | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 106 | RETURN  ${filtered_error_logs} | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 107 |  | 
|  | 108 |  | 
|  | 109 | Get IPMI SEL Setting | 
|  | 110 | [Documentation]  Returns status for given IPMI SEL setting. | 
|  | 111 | [Arguments]  ${setting} | 
|  | 112 | # Description of argument(s): | 
|  | 113 | # setting  SEL setting which needs to be read(e.g. "Last Add Time"). | 
|  | 114 |  | 
|  | 115 | ${resp}=  Run IPMI Standard Command  sel info | 
|  | 116 |  | 
|  | 117 | ${setting_line}=  Get Lines Containing String  ${resp}  ${setting} | 
|  | 118 | ...  case-insensitive | 
|  | 119 | ${setting_status}=  Fetch From Right  ${setting_line}  :${SPACE} | 
|  | 120 |  | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 121 | RETURN  ${setting_status} | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 122 |  | 
|  | 123 |  | 
|  | 124 | Verify Watchdog Errorlog Content | 
|  | 125 | [Documentation]  Verify watchdog errorlog content. | 
|  | 126 | # Example: | 
|  | 127 | # "/xyz/openbmc_project/logging/entry/1": | 
|  | 128 | #  { | 
|  | 129 | #      "AdditionalData": [], | 
|  | 130 | #      "Id": 1, | 
|  | 131 | #      "Message": "org.open_power.Host.Boot.Error.WatchdogTimedOut", | 
|  | 132 | #      "Resolved": 0, | 
|  | 133 | #      "Severity": "xyz.openbmc_project.Logging.Entry.Level.Error", | 
|  | 134 | #      "Timestamp": 1492715244828, | 
| George Keishing | 58520d0 | 2020-02-24 10:55:32 -0600 | [diff] [blame] | 135 | #      "Associations": [] | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 136 | # }, | 
|  | 137 |  | 
|  | 138 | ${elog_entry}=  Get URL List  ${BMC_LOGGING_ENTRY} | 
|  | 139 | ${elog}=  Read Properties  ${elog_entry[0]} | 
|  | 140 | Should Be Equal As Strings | 
|  | 141 | ...  ${elog["Message"]}  org.open_power.Host.Boot.Error.WatchdogTimedOut | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 142 | ...  msg=Watchdog timeout error log was not found. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 143 | Should Be Equal As Strings | 
|  | 144 | ...  ${elog["Severity"]}  xyz.openbmc_project.Logging.Entry.Level.Error | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 145 | ...  msg=Watchdog timeout severity unexpected value. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 146 |  | 
|  | 147 |  | 
|  | 148 | Logging Test Binary Exist | 
|  | 149 | [Documentation]  Verify existence of prerequisite logging-test. | 
| George Keishing | 5f0c1fa | 2022-08-05 13:30:16 -0500 | [diff] [blame] | 150 | ${stdout}  ${stderr}  ${rc}= | 
|  | 151 | ...  BMC Execute Command  test -f /tmp/tarball/bin/logging-test  print_out=1 | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 152 | Should Be Empty  ${stderr}  msg=Logging Test stderr is non-empty. | 
| George Keishing | 5f0c1fa | 2022-08-05 13:30:16 -0500 | [diff] [blame] | 153 |  | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 154 |  | 
|  | 155 | Clear Existing Error Logs | 
|  | 156 | [Documentation]  If error log isn't empty, reboot the BMC to clear the log. | 
|  | 157 | ${resp}=  OpenBMC Get Request  ${BMC_LOGGING_ENTRY}${1} | 
|  | 158 | Return From Keyword If  ${resp.status_code} == ${HTTP_NOT_FOUND} | 
|  | 159 | Initiate BMC Reboot | 
|  | 160 | Wait Until Keyword Succeeds  10 min  10 sec | 
|  | 161 | ...  Is BMC Ready | 
|  | 162 | ${resp}=  OpenBMC Get Request  ${BMC_LOGGING_ENTRY}${1} | 
|  | 163 | Should Be Equal As Strings  ${resp.status_code}  ${HTTP_NOT_FOUND} | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 164 | ...  msg=Could not clear BMC error logs. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 165 |  | 
| Rahul Maheshwari | b8580dd | 2021-05-10 00:57:33 -0500 | [diff] [blame] | 166 |  | 
|  | 167 | Create Test PEL Log | 
|  | 168 | [Documentation]  Generate test PEL log. | 
| Rahul Maheshwari | 55e2346 | 2022-02-16 23:19:35 -0600 | [diff] [blame] | 169 | [Arguments]  ${pel_type}=Unrecoverable Error | 
| Rahul Maheshwari | b8580dd | 2021-05-10 00:57:33 -0500 | [diff] [blame] | 170 |  | 
|  | 171 | # Description of argument(s): | 
|  | 172 | # pel_type      The PEL type (e.g. Internal Failure, FRU Callout, Procedural Callout). | 
|  | 173 |  | 
|  | 174 | # Test PEL log entry example: | 
|  | 175 | # { | 
|  | 176 | #    "0x5000002D": { | 
|  | 177 | #            "SRC": "BD8D1002", | 
|  | 178 | #            "Message": "An application had an internal failure", | 
|  | 179 | #            "PLID": "0x5000002D", | 
|  | 180 | #            "CreatorID": "BMC", | 
|  | 181 | #            "Subsystem": "BMC Firmware", | 
|  | 182 | #            "Commit Time": "02/25/2020  04:47:09", | 
|  | 183 | #            "Sev": "Unrecoverable Error", | 
|  | 184 | #            "CompID": "0x1000" | 
|  | 185 | #    } | 
|  | 186 | # } | 
|  | 187 |  | 
|  | 188 | Run Keyword If  '${pel_type}' == 'Internal Failure' | 
|  | 189 | ...   BMC Execute Command  ${CMD_INTERNAL_FAILURE} | 
|  | 190 | ...  ELSE IF  '${pel_type}' == 'FRU Callout' | 
|  | 191 | ...   BMC Execute Command  ${CMD_FRU_CALLOUT} | 
|  | 192 | ...  ELSE IF  '${pel_type}' == 'Procedure And Symbolic FRU Callout' | 
|  | 193 | ...   BMC Execute Command  ${CMD_PROCEDURAL_SYMBOLIC_FRU_CALLOUT} | 
| Rahul Maheshwari | 55e2346 | 2022-02-16 23:19:35 -0600 | [diff] [blame] | 194 | ...  ELSE IF  '${pel_type}' == 'Unrecoverable Error' | 
|  | 195 | ...   BMC Execute Command  ${CMD_UNRECOVERABLE_ERROR} | 
| Rahul Maheshwari | b8580dd | 2021-05-10 00:57:33 -0500 | [diff] [blame] | 196 |  | 
|  | 197 |  | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 198 | Create Test Error Log | 
|  | 199 | [Documentation]  Generate test error log. | 
|  | 200 | # Test error log entry example: | 
|  | 201 | # "/xyz/openbmc_project/logging/entry/1":  { | 
|  | 202 | #     "AdditionalData": [ | 
|  | 203 | #         "STRING=FOO" | 
|  | 204 | #     ], | 
|  | 205 | #     "Id": 1, | 
|  | 206 | #     "Message": "example.xyz.openbmc_project.Example.Elog.AutoTestSimple", | 
|  | 207 | #     "Severity": "xyz.openbmc_project.Logging.Entry.Level.Error", | 
|  | 208 | #     "Timestamp": 1487743963328, | 
| George Keishing | 58520d0 | 2020-02-24 10:55:32 -0600 | [diff] [blame] | 209 | #     "Associations": [] | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 210 | # } | 
| Joy Onyerikwu | 9b66897 | 2018-05-22 19:10:43 -0500 | [diff] [blame] | 211 | BMC Execute Command  /tmp/tarball/bin/logging-test -c AutoTestSimple | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 212 |  | 
|  | 213 | Count Error Entries | 
|  | 214 | [Documentation]  Count Error entries. | 
|  | 215 | ${resp}=  OpenBMC Get Request  ${BMC_LOGGING_ENTRY} | 
|  | 216 | Should Be Equal As Strings  ${resp.status_code}  ${HTTP_OK} | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 217 | ...  msg=Failed to get error logs. | 
| George Keishing | fbd6700 | 2022-08-01 11:24:03 -0500 | [diff] [blame] | 218 | ${count}=  Get Length  ${resp.json()["data"]} | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 219 | RETURN  ${count} | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 220 |  | 
|  | 221 | Verify Test Error Log | 
|  | 222 | [Documentation]  Verify test error log entries. | 
|  | 223 | ${elog_entry}=  Get URL List  ${BMC_LOGGING_ENTRY} | 
|  | 224 | ${entry_id}=  Read Attribute  ${elog_entry[0]}  Message | 
|  | 225 | Should Be Equal  ${entry_id} | 
|  | 226 | ...  example.xyz.openbmc_project.Example.Elog.AutoTestSimple | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 227 | ...  msg=Error log not from AutoTestSimple. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 228 | ${entry_id}=  Read Attribute  ${elog_entry[0]}  Severity | 
|  | 229 | Should Be Equal  ${entry_id} | 
|  | 230 | ...  xyz.openbmc_project.Logging.Entry.Level.Error | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 231 | ...  msg=Error log severity mismatch. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 232 |  | 
|  | 233 | Delete Error Logs And Verify | 
|  | 234 | [Documentation]  Delete all error logs and verify. | 
|  | 235 | Delete All Error Logs | 
| Steven Sombar | a8800da | 2018-12-18 16:19:05 -0600 | [diff] [blame] | 236 | ${resp}=  OpenBMC Get Request  ${BMC_LOGGING_ENTRY}list  quiet=${1} | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 237 | Should Be Equal As Strings  ${resp.status_code}  ${HTTP_NOT_FOUND} | 
| Sivas SRR | 21c2ef2 | 2018-04-18 11:01:38 -0500 | [diff] [blame] | 238 | ...  msg=Error logs not deleted as expected. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 239 |  | 
|  | 240 |  | 
|  | 241 | Install Tarball | 
|  | 242 | [Documentation]  Install tarball on BMC. | 
| Sivas SRR | f27afbe | 2018-05-26 06:45:23 -0500 | [diff] [blame] | 243 | Should Not Be Empty  ${DEBUG_TARBALL_PATH} | 
|  | 244 | ...  msg=Debug tarball path value is required. | 
| Sivas SRR | cf6714f | 2018-03-26 10:51:29 -0500 | [diff] [blame] | 245 | BMC Execute Command  rm -rf /tmp/tarball | 
|  | 246 | Install Debug Tarball On BMC  ${DEBUG_TARBALL_PATH} | 
| George Keishing | 87e2a85 | 2019-05-29 12:30:14 -0500 | [diff] [blame] | 247 |  | 
|  | 248 |  | 
|  | 249 | Get Event Logs | 
|  | 250 | [Documentation]  Get all available EventLog entries. | 
|  | 251 |  | 
|  | 252 | #{ | 
|  | 253 | #  "@odata.context": "/redfish/v1/$metadata#LogEntryCollection.LogEntryCollection", | 
|  | 254 | #  "@odata.id": "/redfish/v1/Systems/system/LogServices/EventLog/Entries", | 
|  | 255 | #  "@odata.type": "#LogEntryCollection.LogEntryCollection", | 
|  | 256 | #  "Description": "Collection of System Event Log Entries", | 
|  | 257 | #  "Members": [ | 
|  | 258 | #  { | 
|  | 259 | #    "@odata.context": "/redfish/v1/$metadata#LogEntry.LogEntry", | 
|  | 260 | #    "@odata.id": "/redfish/v1/Systems/system/LogServices/EventLog/Entries/1", | 
|  | 261 | #    "@odata.type": "#LogEntry.v1_4_0.LogEntry", | 
|  | 262 | #    "Created": "2019-05-29T13:19:27+00:00", | 
|  | 263 | #    "EntryType": "Event", | 
|  | 264 | #    "Id": "1", | 
|  | 265 | #    "Message": "org.open_power.Host.Error.Event", | 
|  | 266 | #    "Name": "System DBus Event Log Entry", | 
|  | 267 | #    "Severity": "Critical" | 
|  | 268 | #  } | 
|  | 269 | #  ], | 
|  | 270 | #  "Members@odata.count": 1, | 
|  | 271 | #  "Name": "System Event Log Entries" | 
|  | 272 | #} | 
|  | 273 |  | 
| George Keishing | 32f6df6 | 2019-05-29 13:58:12 -0500 | [diff] [blame] | 274 | ${members}=  Redfish.Get Attribute  ${EVENT_LOG_URI}Entries  Members | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 275 | RETURN  ${members} | 
| George Keishing | 32f6df6 | 2019-05-29 13:58:12 -0500 | [diff] [blame] | 276 |  | 
|  | 277 |  | 
| George Keishing | 438fd3b | 2021-10-08 02:15:18 -0500 | [diff] [blame] | 278 | Get Redfish Event Logs | 
|  | 279 | [Documentation]  Pack the list of all available EventLog entries in dictionary. | 
| George Keishing | a6c0089 | 2021-10-11 01:09:54 -0500 | [diff] [blame] | 280 | [Arguments]   ${quiet}=1  &{filter_struct_args} | 
|  | 281 |  | 
|  | 282 | # Description of argument(s): | 
|  | 283 | # quiet                  Indicates whether this keyword should run without any output to the | 
|  | 284 | #                        console, 0 = verbose, 1 = quiet. | 
|  | 285 | # filter_struct_args     filter_struct args (e.g. filter_dict, regex, etc.) to be passed | 
|  | 286 | #                        directly to the Filter Struct keyword.  See its prolog for details. | 
| George Keishing | 438fd3b | 2021-10-08 02:15:18 -0500 | [diff] [blame] | 287 |  | 
|  | 288 | ${packed_dict}=  Create Dictionary | 
|  | 289 | ${error_logs}=  Get Event Logs | 
|  | 290 |  | 
| George Keishing | 1769aa9 | 2021-10-19 10:44:47 -0500 | [diff] [blame] | 291 | FOR  ${idx}   IN  @{error_logs} | 
| George Keishing | 438fd3b | 2021-10-08 02:15:18 -0500 | [diff] [blame] | 292 | Set To Dictionary  ${packed_dict}    ${idx['@odata.id']}=${idx} | 
|  | 293 | END | 
|  | 294 |  | 
| George Keishing | a6c0089 | 2021-10-11 01:09:54 -0500 | [diff] [blame] | 295 | ${num_filter_struct_args}=  Get Length  ${filter_struct_args} | 
|  | 296 | Return From Keyword If  '${num_filter_struct_args}' == '${0}'  &{packed_dict} | 
|  | 297 | ${filtered_error_logs}=  Filter Struct  ${packed_dict}  &{filter_struct_args} | 
|  | 298 |  | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 299 | RETURN  ${filtered_error_logs} | 
| George Keishing | 438fd3b | 2021-10-08 02:15:18 -0500 | [diff] [blame] | 300 |  | 
|  | 301 |  | 
| Joy Onyerikwu | d806cc0 | 2019-10-01 07:46:18 -0500 | [diff] [blame] | 302 | Get Event Logs Not Ok | 
|  | 303 | [Documentation]  Get all event logs where the 'Severity' is not 'OK'. | 
|  | 304 |  | 
|  | 305 | ${members}=  Get Event Logs | 
|  | 306 | ${severe_logs}=  Evaluate  [elog for elog in $members if elog['Severity'] != 'OK'] | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 307 | RETURN  ${severe_logs} | 
| Joy Onyerikwu | d806cc0 | 2019-10-01 07:46:18 -0500 | [diff] [blame] | 308 |  | 
|  | 309 |  | 
| Steven Sombar | 3468df5 | 2019-06-29 11:01:47 -0500 | [diff] [blame] | 310 | Get Number Of Event Logs | 
|  | 311 | [Documentation]  Return the number of EventLog members. | 
|  | 312 |  | 
|  | 313 | ${members}=  Get Event Logs | 
|  | 314 | ${num_members}=  Get Length  ${members} | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 315 | RETURN  ${num_members} | 
| Steven Sombar | 3468df5 | 2019-06-29 11:01:47 -0500 | [diff] [blame] | 316 |  | 
|  | 317 |  | 
| George Keishing | 32f6df6 | 2019-05-29 13:58:12 -0500 | [diff] [blame] | 318 | Redfish Purge Event Log | 
|  | 319 | [Documentation]  Do Redfish EventLog purge. | 
|  | 320 |  | 
| Sushil Singh | eda8bff | 2019-12-05 00:47:13 -0600 | [diff] [blame] | 321 | ${target_action}=  redfish_utils.Get Target Actions | 
| Yi Hu | c32434a | 2024-01-11 17:33:10 -0800 | [diff] [blame] | 322 | ...  /redfish/v1/Systems/${SYSTEM_ID}/LogServices/EventLog/  LogService.ClearLog | 
| Sushil Singh | eda8bff | 2019-12-05 00:47:13 -0600 | [diff] [blame] | 323 | Redfish.Post  ${target_action}  body={'target': '${target_action}'} | 
|  | 324 | ...  valid_status_codes=[${HTTP_OK}, ${HTTP_NO_CONTENT}] | 
|  | 325 |  | 
| Tim Lee | 26393aa | 2022-04-15 11:00:37 +0800 | [diff] [blame] | 326 |  | 
|  | 327 | Event Log Should Not Exist | 
|  | 328 | [Documentation]  Event log entries should not exist. | 
|  | 329 |  | 
|  | 330 | ${elogs}=  Get Event Logs | 
|  | 331 | Should Be Empty  ${elogs}  msg=System event log entry is not empty. | 
| George Keishing | cdfea1d | 2022-08-05 10:42:39 -0500 | [diff] [blame] | 332 |  | 
|  | 333 |  | 
|  | 334 | Redfish Clear PostCodes | 
|  | 335 | [Documentation]  Do Redfish PostCodes purge from system. | 
|  | 336 |  | 
|  | 337 | ${target_action}=  redfish_utils.Get Target Actions | 
| Yi Hu | c32434a | 2024-01-11 17:33:10 -0800 | [diff] [blame] | 338 | ...  /redfish/v1/Systems/${SYSTEM_ID}/LogServices/PostCodes/  LogService.ClearLog | 
| George Keishing | cdfea1d | 2022-08-05 10:42:39 -0500 | [diff] [blame] | 339 | Redfish.Post  ${target_action}  body={'target': '${target_action}'} | 
|  | 340 | ...  valid_status_codes=[${HTTP_OK}, ${HTTP_NO_CONTENT}] | 
|  | 341 |  | 
|  | 342 |  | 
|  | 343 | Redfish Get PostCodes | 
|  | 344 | [Documentation]  Perform Redfish GET request and return the PostCodes entries as a list of dictionaries. | 
|  | 345 |  | 
|  | 346 | # Formatted example output from Rprint vars  members | 
|  | 347 | # members: | 
|  | 348 | #  [0]: | 
|  | 349 | #    [@odata.id]:               /redfish/v1/Systems/system/LogServices/PostCodes/Entries/B1-1 | 
|  | 350 | #    [@odata.type]:             #LogEntry.v1_8_0.LogEntry | 
|  | 351 | #    [AdditionalDataURI]:       /redfish/v1/Systems/system/LogServices/PostCodes/Entries/B1-1/attachment | 
|  | 352 | #    [Created]:                 2022-08-06T04:38:10+00:00 | 
|  | 353 | #    [EntryType]:               Event | 
|  | 354 | #    [Id]:                      B1-1 | 
|  | 355 | #    [Message]:                 Message": "Boot Count: 4: TS Offset: 0.0033; POST Code: 0x43 | 
|  | 356 | #    [MessageArgs]: | 
|  | 357 | #      [0]:                    4 | 
|  | 358 | #      [1]:                    0.0033 | 
|  | 359 | #      [2]:                    0x43 | 
|  | 360 | #    [MessageId]:              OpenBMC.0.2.BIOSPOSTCodeASCII | 
|  | 361 | #    [Name]:                   POST Code Log Entry | 
|  | 362 | #    [Severity]:               OK | 
|  | 363 |  | 
| Yi Hu | c32434a | 2024-01-11 17:33:10 -0800 | [diff] [blame] | 364 | ${members}=  Redfish.Get Attribute  /redfish/v1/Systems/${SYSTEM_ID}/LogServices/PostCodes/Entries  Members | 
| George Keishing | cdfea1d | 2022-08-05 10:42:39 -0500 | [diff] [blame] | 365 | ...  valid_status_codes=[${HTTP_OK}, ${HTTP_NO_CONTENT}] | 
|  | 366 |  | 
| George Keishing | 409df05 | 2024-01-17 22:36:14 +0530 | [diff] [blame] | 367 | RETURN  ${members} | 
| Sridevi Ramesh | 88cc59d | 2025-01-23 03:36:15 -0600 | [diff] [blame] | 368 |  | 
|  | 369 |  | 
|  | 370 | Set Resolve Flag For Event Log | 
|  | 371 | [Documentation]   Set the resolve flag as True or False and verify the valid status code. | 
|  | 372 | [Arguments]  ${bmc_event_id}  ${resolved_flag}  ${valid_status_code}=${HTTP_OK} | 
|  | 373 |  | 
|  | 374 | # Description of argument(s): | 
|  | 375 | # bmc_event_id         BMC event ID. | 
|  | 376 | # resolved_flag        True or False. | 
|  | 377 | # valid_status_code    Redfish valid response code. | 
|  | 378 | #                      Default: ${HTTP_OK} | 
|  | 379 |  | 
|  | 380 | Redfish.Patch  ${EVENT_LOG_URI}Entries/${bmc_event_id}  body={'Resolved':${resolved_flag}} | 
|  | 381 | ...  valid_status_codes=[${valid_status_code}] | 
| Sushil Singh | 51c1b18 | 2025-08-12 04:38:39 -0500 | [diff] [blame] | 382 |  | 
|  | 383 |  | 
|  | 384 | Get Redfish Event Log Entries | 
|  | 385 | [Documentation]  Get the BMC event log entries. | 
|  | 386 |  | 
|  | 387 | # URI : /redfish/v1/Systems/system/LogServices/EventLog/Entries | 
|  | 388 |  | 
|  | 389 | # Sample event log data | 
|  | 390 |  | 
|  | 391 | # '@odata.id': '/redfish/v1/Systems/system/LogServices/EventLog/Entries', | 
|  | 392 | # '@odata.type': '#LogEntryCollection.LogEntryCollection', | 
|  | 393 | # 'Description': 'Collection of System Event Log Entries', | 
|  | 394 | # 'Members': [], | 
|  | 395 | #  'Members@odata.count': 0, | 
|  | 396 | #  'Name': 'System Event Log Entries' | 
|  | 397 |  | 
|  | 398 | ${resp}=  Redfish.Get  ${EVENT_LOG_URI}Entries | 
|  | 399 |  | 
|  | 400 | RETURN  ${resp.dict} | 
|  | 401 |  |