blob: b95b2b1690dcf3c990a9b1e1a56b576810cbd14f [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 ),
72 "PEL_logs_list.json": "peltool -l >/tmp/PEL_logs_list.json 2>&1",
73 "PEL_logs_complete_list.json": (
74 "peltool -l -a -f >/tmp/PEL_logs_complete_list.json 2>&1"
75 ),
76 "PEL_logs_display.json": "peltool -a >/tmp/PEL_logs_display.json 2>&1",
77 "PEL_logs_complete_display.json": (
78 "peltool -a -f -h>/tmp/PEL_logs_complete_display.json 2>&1"
79 ),
George Keishing4afd6552023-02-06 03:08:04 -060080 "PEL_logs_badPEL.txt": (
81 "hexdump -C"
82 + " /var/lib/phosphor-logging/extensions/pels/badPEL>/tmp/PEL_logs_badPEL.txt"
83 " 2>&1"
84 ),
Patrick Williams20f38712022-12-08 06:18:26 -060085 "PLDM_fru_record.txt": (
86 "pldmtool fru getfrurecordtable>/tmp/PLDM_fru_record.txt 2>&1"
87 ),
88 "BMC_pldm_flight_recorder.txt": (
89 "rm -rf /tmp/pldm_flight_recorder; killall -s SIGUSR1 pldmd;"
George Keishing4afd6552023-02-06 03:08:04 -060090 + " sleep 5; cat /tmp/pldm_flight_recorder >"
91 " /tmp/BMC_pldm_flight_recorder.txt 2>&1;"
92 ),
93 "OCC_state.txt": (
94 'echo "OCC state check";for i in {0..3};'
95 + " do (echo /org/open_power/control/occ$i;"
96 + " busctl get-property org.open_power.OCC.Control"
97 " /org/open_power/control/occ$i"
98 + " org.open_power.OCC.Status OccActive) done > /tmp/OCC_state.txt"
99 " 2>&1"
100 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600101 "bmcweb_persistent_data.json": (
102 "cat /home/root/bmcweb_persistent_data.json"
George Keishing4afd6552023-02-06 03:08:04 -0600103 + " > /tmp/bmcweb_persistent_data.json"
104 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600105 "GUARD_list.txt": "guard -l > /tmp/GUARD_list.txt 2>&1",
106 "fan_control_dump.json": "fanctl dump; sleep 5",
107 "DEVTREE": (
108 "cat /var/lib/phosphor-software-manager/pnor/rw/DEVTREE >"
109 " /tmp/DEVTREE 2>&1"
110 ),
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500111 },
112}
George Keishingf9f661d2020-03-18 11:42:53 -0500113# Add file name and corresponding command needed for all Linux distributions
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500114FFDC_OS_ALL_DISTROS_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600115 "OS FILES": {
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500116 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600117 "OS_msglog.txt": (
118 "cat /sys/firmware/opal/msglog >/tmp/OS_msglog.txt 2>&1"
119 ),
George Keishing4afd6552023-02-06 03:08:04 -0600120 "OS_cpufrequency.txt": (
121 "ppc64_cpu --frequency >/tmp/OS_cpufrequency.txt 2>&1"
122 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600123 "OS_dmesg.txt": "dmesg >/tmp/OS_dmesg.txt 2>&1",
124 "OS_opal_prd.txt": "cat /var/log/opal-prd* >/tmp/OS_opal_prd.txt 2>&1",
125 "OS_boot.txt": "cat /var/log/boot.log >/tmp/OS_boot.txt 2>&1",
126 "OS_procinfo.txt": "cat /proc/cpuinfo >/tmp/OS_procinfo.txt 2>&1",
127 "OS_meminfo.txt": "cat /proc/meminfo >/tmp/OS_meminfo.txt 2>&1",
128 "OS_netstat.txt": "netstat -a >/tmp/OS_netstat.txt 2>&1",
129 "OS_lspci.txt": "lspci >/tmp/OS_lspci.txt 2>&1",
130 "OS_lscpu.txt": "lscpu >/tmp/OS_lscpu.txt 2>&1",
131 "OS_lscfg.txt": "lscfg >/tmp/OS_lscfg.txt 2>&1",
George Keishing4afd6552023-02-06 03:08:04 -0600132 "OS_journalctl_nopager.txt": (
133 "journalctl --no-pager -b "
134 + "> /tmp/OS_journalctl_nopager.txt 2>&1"
135 ),
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500136 },
137}
George Keishing671dd662021-05-28 03:26:30 -0500138# Add file name and corresponding command needed for Ubuntu Linux
Gunnar Millscce185d2016-10-17 17:04:15 -0500139FFDC_OS_UBUNTU_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600140 "OS FILES": {
Gunnar Millscce185d2016-10-17 17:04:15 -0500141 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600142 "OS_isusb.txt": "{ lsusb -t ; lsusb -v ; } >/tmp/OS_isusb.txt 2>&1",
143 "OS_kern.txt": (
144 "tail -n 50000 /var/log/kern.log >/tmp/OS_kern.txt 2>&1"
145 ),
146 "OS_authlog.txt": (
147 "{ cat /var/log/auth.log; cat /var/log/auth.log.1 ; } "
George Keishing4afd6552023-02-06 03:08:04 -0600148 + ">/tmp/OS_authlog.txt 2>&1"
149 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600150 "OS_syslog.txt": (
151 "tail -n 200000 /var/log/syslog >/tmp/OS_syslog.txt 2>&1"
152 ),
George Keishing4afd6552023-02-06 03:08:04 -0600153 "OS_info.txt": (
154 "{ uname -a; dpkg -s opal-prd; dpkg -s ipmitool ; } "
155 + ">/tmp/OS_info.txt 2>&1"
156 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600157 "OS_sosreport.txt": (
158 "{ rm -rf /tmp/sosreport*FFDC* ; sosreport --batch --tmp-dir "
George Keishing4afd6552023-02-06 03:08:04 -0600159 + "/tmp --ticket-number FFDC ; } >/tmp/OS_sosreport.txt 2>&1"
160 ),
Gunnar Millscce185d2016-10-17 17:04:15 -0500161 },
162}
George Keishing671dd662021-05-28 03:26:30 -0500163# Add file name and corresponding command needed for RHEL Linux
Gunnar Millscce185d2016-10-17 17:04:15 -0500164FFDC_OS_RHEL_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600165 "OS FILES": {
Gunnar Millscce185d2016-10-17 17:04:15 -0500166 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600167 "OS_rsct.txt": "/usr/bin/ctversion -bv >/tmp/OS_rsct.txt 2>&1",
168 "OS_secure.txt": "cat /var/log/secure >/tmp/OS_secure.txt 2>&1",
George Keishing4afd6552023-02-06 03:08:04 -0600169 "OS_syslog.txt": (
170 "tail -n 200000 /var/log/messages >/tmp/OS_syslog.txt 2>&1"
171 ),
172 "OS_info.txt": (
173 "{ lsb_release -a; cat /etc/redhat-release; "
174 + "uname -a; rpm -qa ; } >/tmp/OS_info.txt 2>&1"
175 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600176 "OS_sosreport.txt": (
177 "{ rm -rf /tmp/sosreport*FFDC* ; sosreport --batch --tmp-dir "
George Keishing4afd6552023-02-06 03:08:04 -0600178 + "/tmp --label FFDC ; } >/tmp/OS_sosreport.txt 2>&1"
179 ),
Gunnar Millscce185d2016-10-17 17:04:15 -0500180 },
181}
George Keishing671dd662021-05-28 03:26:30 -0500182# Add file name and corresponding command needed for AIX.
183FFDC_OS_AIX_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600184 "OS FILES": {
George Keishing671dd662021-05-28 03:26:30 -0500185 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600186 "OS_errpt.txt": "errpt >/tmp/OS_errpt.txt 2>&1 ; errclear 0;",
187 "OS_processors.txt": "bindprocessor -q >/tmp/OS_processors.txt 2>&1",
George Keishing671dd662021-05-28 03:26:30 -0500188 },
189}
George Keishing19700762020-01-22 12:32:53 -0600190
George Keishinga5bbc302021-10-04 22:30:55 -0500191try:
Patrick Williams20f38712022-12-08 06:18:26 -0600192 redfish_support_trans_state = os.environ.get(
193 "REDFISH_SUPPORT_TRANS_STATE", 0
194 ) or int(
195 BuiltIn().get_variable_value(
196 "${REDFISH_SUPPORT_TRANS_STATE}", default=0
197 )
198 )
George Keishinga5bbc302021-10-04 22:30:55 -0500199except RobotNotRunningError:
200 pass
201
Patrick Williams20f38712022-12-08 06:18:26 -0600202OPENBMC_BASE = "/xyz/openbmc_project/"
203OPENPOWER_BASE = "/org/open_power/"
204ENUMERATE_SENSORS = OPENBMC_BASE + "sensors/enumerate"
205ENUMERATE_INVENTORY = OPENBMC_BASE + "inventory/enumerate"
206ENUMERATE_ELOG = OPENBMC_BASE + "logging/entry/enumerate"
207ENUMERATE_LED = OPENBMC_BASE + "led/enumerate"
208ENUMERATE_SW = OPENBMC_BASE + "software/enumerate"
209ENUMERATE_CONTROL = OPENBMC_BASE + "control/enumerate"
210ENUMERATE_STATE = OPENBMC_BASE + "state/enumerate"
211ENUMERATE_OCC = OPENPOWER_BASE + "/enumerate"
212ENUMERATE_DUMPS = OPENBMC_BASE + "dumps/enumerate"
213ENUMERATE_USER = OPENBMC_BASE + "user/enumerate"
Sweta Potthuria82efd62017-10-18 05:34:59 -0500214
George Keishing671dd662021-05-28 03:26:30 -0500215# Add file name and corresponding Get Request
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500216FFDC_GET_REQUEST = {
Patrick Williams20f38712022-12-08 06:18:26 -0600217 "GET REQUESTS": {
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500218 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600219 "FIRMWARE_list.txt": ENUMERATE_SW,
220 "BMC_sensor_list.txt": ENUMERATE_SENSORS,
221 "BMC_control_list.txt": ENUMERATE_CONTROL,
222 "BMC_inventory.txt": ENUMERATE_INVENTORY,
223 "BMC_elog.txt": ENUMERATE_ELOG,
224 "BMC_led.txt": ENUMERATE_LED,
225 "BMC_state.txt": ENUMERATE_STATE,
226 "OCC_state.txt": ENUMERATE_OCC,
227 "BMC_dumps.txt": ENUMERATE_DUMPS,
228 "BMC_USER.txt": ENUMERATE_USER,
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500229 },
230}
George Keishing8c42bbc2021-09-28 14:52:54 -0500231
George Keishinga5bbc302021-10-04 22:30:55 -0500232# Remove the REST dictionary elements.
233if redfish_support_trans_state == 1:
234 for key in list(FFDC_GET_REQUEST):
235 del FFDC_GET_REQUEST[key]
236
Patrick Williams20f38712022-12-08 06:18:26 -0600237REDFISH_BASE = "/redfish/v1/"
238REDFISH_ELOG = REDFISH_BASE + "Systems/system/LogServices/EventLog/Entries"
239REDFISH_FIRMWARE = REDFISH_BASE + "UpdateService/FirmwareInventory"
George Keishing8c42bbc2021-09-28 14:52:54 -0500240
241# Add file name and corresponding Get Request
242FFDC_GET_REDFISH_REQUEST = {
Patrick Williams20f38712022-12-08 06:18:26 -0600243 "GET REQUESTS": {
George Keishing8c42bbc2021-09-28 14:52:54 -0500244 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600245 "BMC_redfish_elog.txt": REDFISH_ELOG,
George Keishing8c42bbc2021-09-28 14:52:54 -0500246 },
247}
248
George Keishing69e6f712016-09-12 06:30:09 -0500249# Define your keywords in method/utils and call here
250FFDC_METHOD_CALL = {
Patrick Williams20f38712022-12-08 06:18:26 -0600251 "BMC LOGS": {
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500252 # Description Keyword name
Patrick Williams20f38712022-12-08 06:18:26 -0600253 "Start ffdc cleanup": "BMC FFDC Cleanup",
254 "FFDC Generic Report": "BMC FFDC Manifest",
255 "BMC Specific Files": "BMC FFDC Files",
256 "Get Request FFDC": "BMC FFDC Get Requests",
257 "Get Redfish Request FFDC": "BMC FFDC Get Redfish Requests",
258 "OS FFDC": "OS FFDC Files",
259 "Core Files": "SCP Coredump Files",
260 "SEL Log": "Collect eSEL Log",
261 "Sys Inventory Files": "System Inventory Files",
262 "Dump Files": "SCP Dump Files",
263 "PEL Files": "Collect PEL Log",
264 "Redfish Log": "Enumerate Redfish Resources",
George Keishing4afd6552023-02-06 03:08:04 -0600265 "Firmware Log": (
266 "Enumerate Redfish Resources "
267 + " enum_uri=/redfish/v1/UpdateService/FirmwareInventory "
268 + " file_enum_name=redfish_FIRMWARE_list.txt"
269 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600270 "Redfish OEM Log": "Enumerate Redfish OEM Resources",
271 "End ffdc cleanup": "BMC FFDC Cleanup",
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500272 },
273}
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300274
George Keishing4b4eef72021-04-01 02:31:42 -0500275try:
Patrick Williams20f38712022-12-08 06:18:26 -0600276 platform_arch_type = os.environ.get(
277 "PLATFORM_ARCH_TYPE", ""
278 ) or BuiltIn().get_variable_value("${PLATFORM_ARCH_TYPE}", default="power")
George Keishing4b4eef72021-04-01 02:31:42 -0500279except RobotNotRunningError:
280 pass
281
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300282# Filter the logs based on platform type.
283if platform_arch_type == "x86":
Patrick Williams20f38712022-12-08 06:18:26 -0600284 del FFDC_BMC_FILE["BMC FILES"]["PEL_logs_list.json"]
285 del FFDC_BMC_FILE["BMC FILES"]["PEL_logs_display.json"]
286 del FFDC_METHOD_CALL["BMC LOGS"]["PEL Files"]
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300287
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500288# -----------------------------------------------------------------
George Keishing4346a412016-07-19 11:26:49 -0500289# base class for FFDC default list
Gunnar Mills096cd562018-03-26 10:19:12 -0500290
291
Patrick Williams20f38712022-12-08 06:18:26 -0600292class openbmc_ffdc_list:
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500293 def get_ffdc_bmc_cmd(self, i_type):
294 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500295 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500296 # @brief This method returns the list from the dictionary for cmds
297 # @param i_type: @type string: string index lookup
298 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500299 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500300 """
George Keishing69e6f712016-09-12 06:30:09 -0500301 return FFDC_BMC_CMD[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500302
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500303 def get_ffdc_bmc_file(self, i_type):
304 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500305 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500306 # @brief This method returns the list from the dictionary for scp
307 # @param i_type: @type string: string index lookup
308 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500309 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500310 """
George Keishing69e6f712016-09-12 06:30:09 -0500311 return FFDC_BMC_FILE[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500312
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500313 def get_ffdc_get_request(self, i_type):
314 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500315 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500316 # @brief This method returns the list from the dictionary for scp
317 # @param i_type: @type string: string index lookup
318 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500319 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500320 """
321 return FFDC_GET_REQUEST[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500322
George Keishing8c42bbc2021-09-28 14:52:54 -0500323 def get_ffdc_get_redfish_request(self, i_type):
324 r"""
325 #######################################################################
326 # @brief This method returns the list from the dictionary for scp
327 # @param i_type: @type string: string index lookup
328 # @return List of key pair from the dictionary
329 #######################################################################
330 """
331 return FFDC_GET_REDFISH_REQUEST[i_type].items()
332
George Keishing69e6f712016-09-12 06:30:09 -0500333 def get_ffdc_cmd_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500334 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500335 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500336 # @brief This method returns the list index from dictionary
337 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500338 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500339 """
George Keishing69e6f712016-09-12 06:30:09 -0500340 return FFDC_BMC_CMD.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500341
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500342 def get_ffdc_get_request_index(self):
343 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500344 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500345 # @brief This method returns the list index from dictionary
346 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500347 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500348 """
349 return FFDC_GET_REQUEST.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500350
George Keishing8c42bbc2021-09-28 14:52:54 -0500351 def get_ffdc_get_redfish_request_index(self):
352 r"""
353 #######################################################################
354 # @brief This method returns the list index from dictionary
355 # @return List of index to the dictionary
356 #######################################################################
357 """
358 return FFDC_GET_REDFISH_REQUEST.keys()
359
George Keishing69e6f712016-09-12 06:30:09 -0500360 def get_ffdc_file_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500361 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500362 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500363 # @brief This method returns the list index from dictionary
364 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500365 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500366 """
George Keishing69e6f712016-09-12 06:30:09 -0500367 return FFDC_BMC_FILE.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500368
George Keishing69e6f712016-09-12 06:30:09 -0500369 def get_ffdc_method_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500370 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500371 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500372 # @brief This method returns the key pair from the dictionary
373 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500374 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500375 """
George Keishing69e6f712016-09-12 06:30:09 -0500376 return FFDC_METHOD_CALL.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500377
Patrick Williams20f38712022-12-08 06:18:26 -0600378 def get_ffdc_method_desc(self, index):
Michael Walshe844e9a2017-04-20 16:51:10 -0500379 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500380 #######################################################################
Michael Walshe844e9a2017-04-20 16:51:10 -0500381 # @brief This method returns the just the keys from the dictionary.
382 # @return List of ffdc descriptions.
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500383 #######################################################################
Michael Walshe844e9a2017-04-20 16:51:10 -0500384 """
385 return FFDC_METHOD_CALL[index].keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500386
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500387 def get_ffdc_method_call(self, i_type):
388 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500389 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500390 # @brief This method returns the key pair from the dictionary
391 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500392 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500393 """
George Keishing69e6f712016-09-12 06:30:09 -0500394 return FFDC_METHOD_CALL[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500395
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500396 def get_ffdc_os_all_distros_index(self):
397 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500398 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500399 # @brief This method returns the key pair from the dictionary
400 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500401 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500402 """
403 return FFDC_OS_ALL_DISTROS_FILE.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500404
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500405 def get_ffdc_os_all_distros_call(self, i_type):
406 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500407 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500408 # @brief This method returns the key pair from the dictionary
409 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500410 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500411 """
412 return FFDC_OS_ALL_DISTROS_FILE[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500413
Gunnar Millscce185d2016-10-17 17:04:15 -0500414 def get_ffdc_os_distro_index(self, distro):
415 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500416 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500417 # @brief This method returns the key pair from the dictionary
418 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500419 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500420 """
421 distro_file = "FFDC_OS_" + str(distro).upper() + "_FILE"
422 return eval(distro_file).keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500423
Gunnar Millscce185d2016-10-17 17:04:15 -0500424 def get_ffdc_os_distro_call(self, i_type, distro):
425 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500426 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500427 # @brief This method returns the key pair from the dictionary
428 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500429 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500430 """
431 distro_file = "FFDC_OS_" + str(distro).upper() + "_FILE"
432 return eval(distro_file)[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500433
George Keishing4346a412016-07-19 11:26:49 -0500434 def get_strip_string(self, i_str):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500435 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500436 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500437 # @brief Returns the stripped strings
438 # @param i_str: @type string: string name
439 # @return Remove all special chars and return the string
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500440 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500441 """
Patrick Williams20f38712022-12-08 06:18:26 -0600442 return "".join(e for e in i_str if e.isalnum())
Gunnar Mills096cd562018-03-26 10:19:12 -0500443
George Keishing28da9482017-07-27 13:38:54 -0500444 def get_esel_index(self, esel_list):
445 r"""
446 #######################################################################
447 # @brief Returns the eSEL binary index.
448 # @param esel_ist: @type list: eSEL list.
449 # @return Index of "ESEL=" in the list.
450 #######################################################################
451 """
Patrick Williams20f38712022-12-08 06:18:26 -0600452 index = [i for i, str in enumerate(esel_list) if "ESEL=" in str]
George Keishing28da9482017-07-27 13:38:54 -0500453 return index[0]
Sweta Potthuria82efd62017-10-18 05:34:59 -0500454
455 def get_dump_index(self, dump_list):
456 r"""
457 #######################################################################
458 # @brief Returns the eSEL binary index.
459 # @param esel_ist: @type list: eSEL list.
460 # @return Index of "ESEL=" in the list.
461 #######################################################################
462 """
Patrick Williams20f38712022-12-08 06:18:26 -0600463 index = [i for i, str in enumerate(dump_list) if "DUMP=" in str]
Sweta Potthuria82efd62017-10-18 05:34:59 -0500464 return index[0]