blob: 6e334812b2c46c7d01f27e202aae4edd1cc894bd [file] [log] [blame]
George Keishinge7e91712021-09-03 11:28:44 -05001#!/usr/bin/env python3
Gunnar Millsa812e0f2016-09-29 20:30:03 -05002r"""
George Keishing4346a412016-07-19 11:26:49 -05003# @file openbmc_ffdc_list.py
George Keishing4346a412016-07-19 11:26:49 -05004# @brief List for FFDC ( First failure data capture )
5# commands and files to be collected as a part
6# of the test case failure.
Gunnar Millsa812e0f2016-09-29 20:30:03 -05007"""
Konstantin Aladyshevc056c2b2021-03-25 11:59:39 +03008import os
9
Konstantin Aladyshev67880492021-03-20 17:20:57 +030010from robot.libraries.BuiltIn import BuiltIn
11
Gunnar Millsa812e0f2016-09-29 20:30:03 -050012# -------------------
George Keishing4346a412016-07-19 11:26:49 -050013# FFDC default list
Gunnar Millsa812e0f2016-09-29 20:30:03 -050014# -------------------
Gunnar Millsa812e0f2016-09-29 20:30:03 -050015# -----------------------------------------------------------------
Gunnar Mills28e403b2017-10-25 16:16:38 -050016# Dict Name { Index string : { Key String : Command string} }
Gunnar Millsa812e0f2016-09-29 20:30:03 -050017# -----------------------------------------------------------------
George Keishing69e6f712016-09-12 06:30:09 -050018# Add cmd's needed to be part of the ffdc report manifest file
19FFDC_BMC_CMD = {
Patrick Williams20f38712022-12-08 06:18:26 -060020 "DRIVER INFO": {
Gunnar Millsa812e0f2016-09-29 20:30:03 -050021 # String Name Command
Patrick Williams20f38712022-12-08 06:18:26 -060022 "FW Level": "cat /etc/os-release",
23 "FW Timestamp": "cat /etc/timestamp",
Gunnar Millsa812e0f2016-09-29 20:30:03 -050024 },
Patrick Williams20f38712022-12-08 06:18:26 -060025 "BMC DATA": {
26 "BMC OS": "uname -a",
27 "BMC Uptime": "uptime;cat /proc/uptime",
28 "BMC File System Disk Space Usage": "df -hT",
29 "BMC Date Time": "date;/sbin/hwclock --show;/usr/bin/timedatectl",
Gunnar Millsa812e0f2016-09-29 20:30:03 -050030 },
Patrick Williams20f38712022-12-08 06:18:26 -060031 "APPLICATION DATA": {
32 "BMC state": "/usr/bin/obmcutil state",
Gunnar Millsa812e0f2016-09-29 20:30:03 -050033 },
34}
George Keishing671dd662021-05-28 03:26:30 -050035# Add file name and corresponding command needed for BMC
George Keishing69e6f712016-09-12 06:30:09 -050036FFDC_BMC_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -060037 "BMC FILES": {
Gunnar Millsa812e0f2016-09-29 20:30:03 -050038 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -060039 "BMC_flash_side.txt": (
40 "cat /sys/class/watchdog/watchdog1/bootstatus"
41 " >/tmp/BMC_flash_side.txt 2>&1"
42 ),
43 "BMC_hwmon.txt": (
44 "grep -r . /sys/class/hwmon/* >/tmp/BMC_hwmon.txt 2>&1"
45 ),
46 "BMC_proc_list.txt": "top -n 1 -b >/tmp/BMC_proc_list.txt 2>&1",
47 "BMC_proc_fd_active_list.txt": (
48 "ls -Al /proc/*/fd/ >/tmp/BMC_proc_fd_active_list.txt 2>&1"
49 ),
50 "BMC_journalctl_nopager.txt": (
51 "journalctl --no-pager >/tmp/BMC_journalctl_nopager.txt 2>&1"
52 ),
53 "BMC_journalctl_pretty.json": (
54 "journalctl -o json-pretty >/tmp/BMC_journalctl_pretty.json 2>&1"
55 ),
56 "BMC_dmesg.txt": "dmesg >/tmp/BMC_dmesg.txt 2>&1",
57 "BMC_procinfo.txt": "cat /proc/cpuinfo >/tmp/BMC_procinfo.txt 2>&1",
58 "BMC_meminfo.txt": "cat /proc/meminfo >/tmp/BMC_meminfo.txt 2>&1",
59 "BMC_systemd.txt": "systemctl status --all >/tmp/BMC_systemd.txt 2>&1",
60 "BMC_failed_service.txt": (
61 "systemctl list-units --failed >/tmp/BMC_failed_service.txt 2>&1"
62 ),
63 "BMC_list_service.txt": (
64 "systemctl list-jobs >/tmp/BMC_list_service.txt 2>&1"
65 ),
66 "BMC_obmc_console.txt": (
67 "cat /var/log/obmc-console.log >/tmp/BMC_obmc_console.txt 2>&1"
68 ),
69 "BMC_obmc_console1.txt": (
70 "cat /var/log/obmc-console1.log >/tmp/BMC_obmc_console1.txt 2>&1"
71 ),
George Keishingecf44282024-05-20 20:44:17 +053072 "vpd-inventory.txt": "vpd-tool -i >/tmp/vpd-inventory.txt 2>&1",
Patrick Williams20f38712022-12-08 06:18:26 -060073 "PEL_logs_list.json": "peltool -l >/tmp/PEL_logs_list.json 2>&1",
74 "PEL_logs_complete_list.json": (
75 "peltool -l -a -f >/tmp/PEL_logs_complete_list.json 2>&1"
76 ),
77 "PEL_logs_display.json": "peltool -a >/tmp/PEL_logs_display.json 2>&1",
78 "PEL_logs_complete_display.json": (
79 "peltool -a -f -h>/tmp/PEL_logs_complete_display.json 2>&1"
80 ),
George Keishing4afd6552023-02-06 03:08:04 -060081 "PEL_logs_badPEL.txt": (
82 "hexdump -C"
83 + " /var/lib/phosphor-logging/extensions/pels/badPEL>/tmp/PEL_logs_badPEL.txt"
84 " 2>&1"
85 ),
Patrick Williams20f38712022-12-08 06:18:26 -060086 "PLDM_fru_record.txt": (
87 "pldmtool fru getfrurecordtable>/tmp/PLDM_fru_record.txt 2>&1"
88 ),
89 "BMC_pldm_flight_recorder.txt": (
90 "rm -rf /tmp/pldm_flight_recorder; killall -s SIGUSR1 pldmd;"
George Keishing4afd6552023-02-06 03:08:04 -060091 + " sleep 5; cat /tmp/pldm_flight_recorder >"
92 " /tmp/BMC_pldm_flight_recorder.txt 2>&1;"
93 ),
94 "OCC_state.txt": (
95 'echo "OCC state check";for i in {0..3};'
96 + " do (echo /org/open_power/control/occ$i;"
97 + " busctl get-property org.open_power.OCC.Control"
98 " /org/open_power/control/occ$i"
99 + " org.open_power.OCC.Status OccActive) done > /tmp/OCC_state.txt"
100 " 2>&1"
101 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600102 "GUARD_list.txt": "guard -l > /tmp/GUARD_list.txt 2>&1",
103 "fan_control_dump.json": "fanctl dump; sleep 5",
George Keishing326e41b2023-12-13 14:52:45 +0530104 "fan_monitor_dump.json": "killall -s SIGUSR1 phosphor-fan-monitor; sleep 5",
Patrick Williams20f38712022-12-08 06:18:26 -0600105 "DEVTREE": (
106 "cat /var/lib/phosphor-software-manager/pnor/rw/DEVTREE >"
107 " /tmp/DEVTREE 2>&1"
108 ),
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500109 },
110}
George Keishingf9f661d2020-03-18 11:42:53 -0500111# Add file name and corresponding command needed for all Linux distributions
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500112FFDC_OS_ALL_DISTROS_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600113 "OS FILES": {
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500114 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600115 "OS_msglog.txt": (
116 "cat /sys/firmware/opal/msglog >/tmp/OS_msglog.txt 2>&1"
117 ),
George Keishing4afd6552023-02-06 03:08:04 -0600118 "OS_cpufrequency.txt": (
119 "ppc64_cpu --frequency >/tmp/OS_cpufrequency.txt 2>&1"
120 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600121 "OS_dmesg.txt": "dmesg >/tmp/OS_dmesg.txt 2>&1",
122 "OS_opal_prd.txt": "cat /var/log/opal-prd* >/tmp/OS_opal_prd.txt 2>&1",
123 "OS_boot.txt": "cat /var/log/boot.log >/tmp/OS_boot.txt 2>&1",
124 "OS_procinfo.txt": "cat /proc/cpuinfo >/tmp/OS_procinfo.txt 2>&1",
125 "OS_meminfo.txt": "cat /proc/meminfo >/tmp/OS_meminfo.txt 2>&1",
126 "OS_netstat.txt": "netstat -a >/tmp/OS_netstat.txt 2>&1",
127 "OS_lspci.txt": "lspci >/tmp/OS_lspci.txt 2>&1",
128 "OS_lscpu.txt": "lscpu >/tmp/OS_lscpu.txt 2>&1",
129 "OS_lscfg.txt": "lscfg >/tmp/OS_lscfg.txt 2>&1",
George Keishing4afd6552023-02-06 03:08:04 -0600130 "OS_journalctl_nopager.txt": (
131 "journalctl --no-pager -b "
132 + "> /tmp/OS_journalctl_nopager.txt 2>&1"
133 ),
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500134 },
135}
George Keishing671dd662021-05-28 03:26:30 -0500136# Add file name and corresponding command needed for Ubuntu Linux
Gunnar Millscce185d2016-10-17 17:04:15 -0500137FFDC_OS_UBUNTU_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600138 "OS FILES": {
Gunnar Millscce185d2016-10-17 17:04:15 -0500139 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600140 "OS_isusb.txt": "{ lsusb -t ; lsusb -v ; } >/tmp/OS_isusb.txt 2>&1",
141 "OS_kern.txt": (
142 "tail -n 50000 /var/log/kern.log >/tmp/OS_kern.txt 2>&1"
143 ),
144 "OS_authlog.txt": (
145 "{ cat /var/log/auth.log; cat /var/log/auth.log.1 ; } "
George Keishing4afd6552023-02-06 03:08:04 -0600146 + ">/tmp/OS_authlog.txt 2>&1"
147 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600148 "OS_syslog.txt": (
149 "tail -n 200000 /var/log/syslog >/tmp/OS_syslog.txt 2>&1"
150 ),
George Keishing4afd6552023-02-06 03:08:04 -0600151 "OS_info.txt": (
152 "{ uname -a; dpkg -s opal-prd; dpkg -s ipmitool ; } "
153 + ">/tmp/OS_info.txt 2>&1"
154 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600155 "OS_sosreport.txt": (
156 "{ rm -rf /tmp/sosreport*FFDC* ; sosreport --batch --tmp-dir "
George Keishing4afd6552023-02-06 03:08:04 -0600157 + "/tmp --ticket-number FFDC ; } >/tmp/OS_sosreport.txt 2>&1"
158 ),
Gunnar Millscce185d2016-10-17 17:04:15 -0500159 },
160}
George Keishing671dd662021-05-28 03:26:30 -0500161# Add file name and corresponding command needed for RHEL Linux
Gunnar Millscce185d2016-10-17 17:04:15 -0500162FFDC_OS_RHEL_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600163 "OS FILES": {
Gunnar Millscce185d2016-10-17 17:04:15 -0500164 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600165 "OS_rsct.txt": "/usr/bin/ctversion -bv >/tmp/OS_rsct.txt 2>&1",
166 "OS_secure.txt": "cat /var/log/secure >/tmp/OS_secure.txt 2>&1",
George Keishing4afd6552023-02-06 03:08:04 -0600167 "OS_syslog.txt": (
168 "tail -n 200000 /var/log/messages >/tmp/OS_syslog.txt 2>&1"
169 ),
170 "OS_info.txt": (
171 "{ lsb_release -a; cat /etc/redhat-release; "
172 + "uname -a; rpm -qa ; } >/tmp/OS_info.txt 2>&1"
173 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600174 "OS_sosreport.txt": (
175 "{ rm -rf /tmp/sosreport*FFDC* ; sosreport --batch --tmp-dir "
George Keishing4afd6552023-02-06 03:08:04 -0600176 + "/tmp --label FFDC ; } >/tmp/OS_sosreport.txt 2>&1"
177 ),
Gunnar Millscce185d2016-10-17 17:04:15 -0500178 },
179}
George Keishing671dd662021-05-28 03:26:30 -0500180# Add file name and corresponding command needed for AIX.
181FFDC_OS_AIX_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600182 "OS FILES": {
George Keishing671dd662021-05-28 03:26:30 -0500183 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600184 "OS_errpt.txt": "errpt >/tmp/OS_errpt.txt 2>&1 ; errclear 0;",
185 "OS_processors.txt": "bindprocessor -q >/tmp/OS_processors.txt 2>&1",
George Keishing671dd662021-05-28 03:26:30 -0500186 },
187}
George Keishing19700762020-01-22 12:32:53 -0600188
George Keishinga5bbc302021-10-04 22:30:55 -0500189try:
Patrick Williams20f38712022-12-08 06:18:26 -0600190 redfish_support_trans_state = os.environ.get(
191 "REDFISH_SUPPORT_TRANS_STATE", 0
192 ) or int(
193 BuiltIn().get_variable_value(
194 "${REDFISH_SUPPORT_TRANS_STATE}", default=0
195 )
196 )
George Keishinga5bbc302021-10-04 22:30:55 -0500197except RobotNotRunningError:
198 pass
199
Patrick Williams20f38712022-12-08 06:18:26 -0600200OPENBMC_BASE = "/xyz/openbmc_project/"
201OPENPOWER_BASE = "/org/open_power/"
202ENUMERATE_SENSORS = OPENBMC_BASE + "sensors/enumerate"
203ENUMERATE_INVENTORY = OPENBMC_BASE + "inventory/enumerate"
204ENUMERATE_ELOG = OPENBMC_BASE + "logging/entry/enumerate"
205ENUMERATE_LED = OPENBMC_BASE + "led/enumerate"
206ENUMERATE_SW = OPENBMC_BASE + "software/enumerate"
207ENUMERATE_CONTROL = OPENBMC_BASE + "control/enumerate"
208ENUMERATE_STATE = OPENBMC_BASE + "state/enumerate"
209ENUMERATE_OCC = OPENPOWER_BASE + "/enumerate"
210ENUMERATE_DUMPS = OPENBMC_BASE + "dumps/enumerate"
211ENUMERATE_USER = OPENBMC_BASE + "user/enumerate"
Sweta Potthuria82efd62017-10-18 05:34:59 -0500212
George Keishing671dd662021-05-28 03:26:30 -0500213# Add file name and corresponding Get Request
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500214FFDC_GET_REQUEST = {
Patrick Williams20f38712022-12-08 06:18:26 -0600215 "GET REQUESTS": {
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500216 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600217 "FIRMWARE_list.txt": ENUMERATE_SW,
218 "BMC_sensor_list.txt": ENUMERATE_SENSORS,
219 "BMC_control_list.txt": ENUMERATE_CONTROL,
220 "BMC_inventory.txt": ENUMERATE_INVENTORY,
221 "BMC_elog.txt": ENUMERATE_ELOG,
222 "BMC_led.txt": ENUMERATE_LED,
223 "BMC_state.txt": ENUMERATE_STATE,
224 "OCC_state.txt": ENUMERATE_OCC,
225 "BMC_dumps.txt": ENUMERATE_DUMPS,
226 "BMC_USER.txt": ENUMERATE_USER,
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500227 },
228}
George Keishing8c42bbc2021-09-28 14:52:54 -0500229
George Keishinga5bbc302021-10-04 22:30:55 -0500230# Remove the REST dictionary elements.
231if redfish_support_trans_state == 1:
232 for key in list(FFDC_GET_REQUEST):
233 del FFDC_GET_REQUEST[key]
234
Patrick Williams20f38712022-12-08 06:18:26 -0600235REDFISH_BASE = "/redfish/v1/"
Patrick Williams20f38712022-12-08 06:18:26 -0600236REDFISH_FIRMWARE = REDFISH_BASE + "UpdateService/FirmwareInventory"
George Keishing8c42bbc2021-09-28 14:52:54 -0500237
Yi Huc32434a2024-01-11 17:33:10 -0800238try:
239 REDFISH_SYSTEM_ID = REDFISH_SYSTEM_ID = os.environ.get(
240 "SYSTEM_ID", ""
241 ) or BuiltIn().get_variable_value("${SYSTEM_ID}", default="system")
242
243 REDFISH_ELOG = (
244 REDFISH_BASE
245 + "Systems/"
246 + REDFISH_SYSTEM_ID
247 + "/LogServices/EventLog/Entries"
248 )
249except RobotNotRunningError:
250 REDFISH_ELOG = REDFISH_BASE + "Systems/system/LogServices/EventLog/Entries"
251 pass
252
George Keishing8c42bbc2021-09-28 14:52:54 -0500253# Add file name and corresponding Get Request
254FFDC_GET_REDFISH_REQUEST = {
Patrick Williams20f38712022-12-08 06:18:26 -0600255 "GET REQUESTS": {
George Keishing8c42bbc2021-09-28 14:52:54 -0500256 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600257 "BMC_redfish_elog.txt": REDFISH_ELOG,
George Keishing8c42bbc2021-09-28 14:52:54 -0500258 },
259}
260
George Keishing69e6f712016-09-12 06:30:09 -0500261# Define your keywords in method/utils and call here
262FFDC_METHOD_CALL = {
Patrick Williams20f38712022-12-08 06:18:26 -0600263 "BMC LOGS": {
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500264 # Description Keyword name
Patrick Williams20f38712022-12-08 06:18:26 -0600265 "Start ffdc cleanup": "BMC FFDC Cleanup",
266 "FFDC Generic Report": "BMC FFDC Manifest",
267 "BMC Specific Files": "BMC FFDC Files",
268 "Get Request FFDC": "BMC FFDC Get Requests",
269 "Get Redfish Request FFDC": "BMC FFDC Get Redfish Requests",
270 "OS FFDC": "OS FFDC Files",
271 "Core Files": "SCP Coredump Files",
272 "SEL Log": "Collect eSEL Log",
273 "Sys Inventory Files": "System Inventory Files",
274 "Dump Files": "SCP Dump Files",
275 "PEL Files": "Collect PEL Log",
276 "Redfish Log": "Enumerate Redfish Resources",
George Keishing4afd6552023-02-06 03:08:04 -0600277 "Firmware Log": (
278 "Enumerate Redfish Resources "
279 + " enum_uri=/redfish/v1/UpdateService/FirmwareInventory "
280 + " file_enum_name=redfish_FIRMWARE_list.txt"
281 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600282 "Redfish OEM Log": "Enumerate Redfish OEM Resources",
283 "End ffdc cleanup": "BMC FFDC Cleanup",
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500284 },
285}
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300286
George Keishing4b4eef72021-04-01 02:31:42 -0500287try:
Patrick Williams20f38712022-12-08 06:18:26 -0600288 platform_arch_type = os.environ.get(
289 "PLATFORM_ARCH_TYPE", ""
290 ) or BuiltIn().get_variable_value("${PLATFORM_ARCH_TYPE}", default="power")
George Keishing4b4eef72021-04-01 02:31:42 -0500291except RobotNotRunningError:
292 pass
293
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300294# Filter the logs based on platform type.
295if platform_arch_type == "x86":
Patrick Williams20f38712022-12-08 06:18:26 -0600296 del FFDC_BMC_FILE["BMC FILES"]["PEL_logs_list.json"]
297 del FFDC_BMC_FILE["BMC FILES"]["PEL_logs_display.json"]
298 del FFDC_METHOD_CALL["BMC LOGS"]["PEL Files"]
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300299
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500300# -----------------------------------------------------------------
George Keishing4346a412016-07-19 11:26:49 -0500301# base class for FFDC default list
Gunnar Mills096cd562018-03-26 10:19:12 -0500302
303
Patrick Williams20f38712022-12-08 06:18:26 -0600304class openbmc_ffdc_list:
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500305 def get_ffdc_bmc_cmd(self, i_type):
306 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500307 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500308 # @brief This method returns the list from the dictionary for cmds
309 # @param i_type: @type string: string index lookup
310 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500311 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500312 """
George Keishing69e6f712016-09-12 06:30:09 -0500313 return FFDC_BMC_CMD[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500314
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500315 def get_ffdc_bmc_file(self, i_type):
316 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500317 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500318 # @brief This method returns the list from the dictionary for scp
319 # @param i_type: @type string: string index lookup
320 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500321 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500322 """
George Keishing69e6f712016-09-12 06:30:09 -0500323 return FFDC_BMC_FILE[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500324
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500325 def get_ffdc_get_request(self, i_type):
326 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500327 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500328 # @brief This method returns the list from the dictionary for scp
329 # @param i_type: @type string: string index lookup
330 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500331 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500332 """
333 return FFDC_GET_REQUEST[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500334
George Keishing8c42bbc2021-09-28 14:52:54 -0500335 def get_ffdc_get_redfish_request(self, i_type):
336 r"""
337 #######################################################################
338 # @brief This method returns the list from the dictionary for scp
339 # @param i_type: @type string: string index lookup
340 # @return List of key pair from the dictionary
341 #######################################################################
342 """
343 return FFDC_GET_REDFISH_REQUEST[i_type].items()
344
George Keishing69e6f712016-09-12 06:30:09 -0500345 def get_ffdc_cmd_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500346 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500347 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500348 # @brief This method returns the list index from dictionary
349 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500350 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500351 """
George Keishing69e6f712016-09-12 06:30:09 -0500352 return FFDC_BMC_CMD.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500353
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500354 def get_ffdc_get_request_index(self):
355 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500356 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500357 # @brief This method returns the list index from dictionary
358 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500359 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500360 """
361 return FFDC_GET_REQUEST.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500362
George Keishing8c42bbc2021-09-28 14:52:54 -0500363 def get_ffdc_get_redfish_request_index(self):
364 r"""
365 #######################################################################
366 # @brief This method returns the list index from dictionary
367 # @return List of index to the dictionary
368 #######################################################################
369 """
370 return FFDC_GET_REDFISH_REQUEST.keys()
371
George Keishing69e6f712016-09-12 06:30:09 -0500372 def get_ffdc_file_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500373 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500374 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500375 # @brief This method returns the list index from dictionary
376 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500377 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500378 """
George Keishing69e6f712016-09-12 06:30:09 -0500379 return FFDC_BMC_FILE.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500380
George Keishing69e6f712016-09-12 06:30:09 -0500381 def get_ffdc_method_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500382 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500383 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500384 # @brief This method returns the key pair from the dictionary
385 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500386 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500387 """
George Keishing69e6f712016-09-12 06:30:09 -0500388 return FFDC_METHOD_CALL.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500389
Patrick Williams20f38712022-12-08 06:18:26 -0600390 def get_ffdc_method_desc(self, index):
Michael Walshe844e9a2017-04-20 16:51:10 -0500391 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500392 #######################################################################
Michael Walshe844e9a2017-04-20 16:51:10 -0500393 # @brief This method returns the just the keys from the dictionary.
394 # @return List of ffdc descriptions.
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500395 #######################################################################
Michael Walshe844e9a2017-04-20 16:51:10 -0500396 """
397 return FFDC_METHOD_CALL[index].keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500398
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500399 def get_ffdc_method_call(self, i_type):
400 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500401 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500402 # @brief This method returns the key pair from the dictionary
403 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500404 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500405 """
George Keishing69e6f712016-09-12 06:30:09 -0500406 return FFDC_METHOD_CALL[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500407
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500408 def get_ffdc_os_all_distros_index(self):
409 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500410 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500411 # @brief This method returns the key pair from the dictionary
412 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500413 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500414 """
415 return FFDC_OS_ALL_DISTROS_FILE.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500416
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500417 def get_ffdc_os_all_distros_call(self, i_type):
418 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500419 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500420 # @brief This method returns the key pair from the dictionary
421 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500422 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500423 """
424 return FFDC_OS_ALL_DISTROS_FILE[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500425
Gunnar Millscce185d2016-10-17 17:04:15 -0500426 def get_ffdc_os_distro_index(self, distro):
427 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500428 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500429 # @brief This method returns the key pair from the dictionary
430 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500431 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500432 """
433 distro_file = "FFDC_OS_" + str(distro).upper() + "_FILE"
434 return eval(distro_file).keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500435
Gunnar Millscce185d2016-10-17 17:04:15 -0500436 def get_ffdc_os_distro_call(self, i_type, distro):
437 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500438 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500439 # @brief This method returns the key pair from the dictionary
440 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500441 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500442 """
443 distro_file = "FFDC_OS_" + str(distro).upper() + "_FILE"
444 return eval(distro_file)[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500445
George Keishing4346a412016-07-19 11:26:49 -0500446 def get_strip_string(self, i_str):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500447 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500448 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500449 # @brief Returns the stripped strings
450 # @param i_str: @type string: string name
451 # @return Remove all special chars and return the string
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500452 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500453 """
Patrick Williams20f38712022-12-08 06:18:26 -0600454 return "".join(e for e in i_str if e.isalnum())
Gunnar Mills096cd562018-03-26 10:19:12 -0500455
George Keishing28da9482017-07-27 13:38:54 -0500456 def get_esel_index(self, esel_list):
457 r"""
458 #######################################################################
459 # @brief Returns the eSEL binary index.
460 # @param esel_ist: @type list: eSEL list.
461 # @return Index of "ESEL=" in the list.
462 #######################################################################
463 """
Patrick Williams20f38712022-12-08 06:18:26 -0600464 index = [i for i, str in enumerate(esel_list) if "ESEL=" in str]
George Keishing28da9482017-07-27 13:38:54 -0500465 return index[0]
Sweta Potthuria82efd62017-10-18 05:34:59 -0500466
467 def get_dump_index(self, dump_list):
468 r"""
469 #######################################################################
470 # @brief Returns the eSEL binary index.
471 # @param esel_ist: @type list: eSEL list.
472 # @return Index of "ESEL=" in the list.
473 #######################################################################
474 """
Patrick Williams20f38712022-12-08 06:18:26 -0600475 index = [i for i, str in enumerate(dump_list) if "DUMP=" in str]
Sweta Potthuria82efd62017-10-18 05:34:59 -0500476 return index[0]