blob: a6218f20e214fa2bb711c30366212bc4d0f31cd1 [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 ),
George Keishing706785c2024-12-04 16:04:32 +0530109 "kernel_sys_trace.txt": (
110 "cat /sys/kernel/tracing/trace >/tmp/kernel_sys_trace.txt 2>&1"
111 ),
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500112 },
113}
George Keishingf9f661d2020-03-18 11:42:53 -0500114# Add file name and corresponding command needed for all Linux distributions
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500115FFDC_OS_ALL_DISTROS_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600116 "OS FILES": {
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500117 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600118 "OS_msglog.txt": (
119 "cat /sys/firmware/opal/msglog >/tmp/OS_msglog.txt 2>&1"
120 ),
George Keishing4afd6552023-02-06 03:08:04 -0600121 "OS_cpufrequency.txt": (
122 "ppc64_cpu --frequency >/tmp/OS_cpufrequency.txt 2>&1"
123 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600124 "OS_dmesg.txt": "dmesg >/tmp/OS_dmesg.txt 2>&1",
125 "OS_opal_prd.txt": "cat /var/log/opal-prd* >/tmp/OS_opal_prd.txt 2>&1",
126 "OS_boot.txt": "cat /var/log/boot.log >/tmp/OS_boot.txt 2>&1",
127 "OS_procinfo.txt": "cat /proc/cpuinfo >/tmp/OS_procinfo.txt 2>&1",
128 "OS_meminfo.txt": "cat /proc/meminfo >/tmp/OS_meminfo.txt 2>&1",
129 "OS_netstat.txt": "netstat -a >/tmp/OS_netstat.txt 2>&1",
130 "OS_lspci.txt": "lspci >/tmp/OS_lspci.txt 2>&1",
131 "OS_lscpu.txt": "lscpu >/tmp/OS_lscpu.txt 2>&1",
132 "OS_lscfg.txt": "lscfg >/tmp/OS_lscfg.txt 2>&1",
George Keishing4afd6552023-02-06 03:08:04 -0600133 "OS_journalctl_nopager.txt": (
134 "journalctl --no-pager -b "
135 + "> /tmp/OS_journalctl_nopager.txt 2>&1"
136 ),
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500137 },
138}
George Keishing671dd662021-05-28 03:26:30 -0500139# Add file name and corresponding command needed for Ubuntu Linux
Gunnar Millscce185d2016-10-17 17:04:15 -0500140FFDC_OS_UBUNTU_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600141 "OS FILES": {
Gunnar Millscce185d2016-10-17 17:04:15 -0500142 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600143 "OS_isusb.txt": "{ lsusb -t ; lsusb -v ; } >/tmp/OS_isusb.txt 2>&1",
144 "OS_kern.txt": (
145 "tail -n 50000 /var/log/kern.log >/tmp/OS_kern.txt 2>&1"
146 ),
147 "OS_authlog.txt": (
148 "{ cat /var/log/auth.log; cat /var/log/auth.log.1 ; } "
George Keishing4afd6552023-02-06 03:08:04 -0600149 + ">/tmp/OS_authlog.txt 2>&1"
150 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600151 "OS_syslog.txt": (
152 "tail -n 200000 /var/log/syslog >/tmp/OS_syslog.txt 2>&1"
153 ),
George Keishing4afd6552023-02-06 03:08:04 -0600154 "OS_info.txt": (
155 "{ uname -a; dpkg -s opal-prd; dpkg -s ipmitool ; } "
156 + ">/tmp/OS_info.txt 2>&1"
157 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600158 "OS_sosreport.txt": (
159 "{ rm -rf /tmp/sosreport*FFDC* ; sosreport --batch --tmp-dir "
George Keishing4afd6552023-02-06 03:08:04 -0600160 + "/tmp --ticket-number FFDC ; } >/tmp/OS_sosreport.txt 2>&1"
161 ),
Gunnar Millscce185d2016-10-17 17:04:15 -0500162 },
163}
George Keishing671dd662021-05-28 03:26:30 -0500164# Add file name and corresponding command needed for RHEL Linux
Gunnar Millscce185d2016-10-17 17:04:15 -0500165FFDC_OS_RHEL_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600166 "OS FILES": {
Gunnar Millscce185d2016-10-17 17:04:15 -0500167 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600168 "OS_rsct.txt": "/usr/bin/ctversion -bv >/tmp/OS_rsct.txt 2>&1",
169 "OS_secure.txt": "cat /var/log/secure >/tmp/OS_secure.txt 2>&1",
George Keishing4afd6552023-02-06 03:08:04 -0600170 "OS_syslog.txt": (
171 "tail -n 200000 /var/log/messages >/tmp/OS_syslog.txt 2>&1"
172 ),
173 "OS_info.txt": (
174 "{ lsb_release -a; cat /etc/redhat-release; "
175 + "uname -a; rpm -qa ; } >/tmp/OS_info.txt 2>&1"
176 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600177 "OS_sosreport.txt": (
178 "{ rm -rf /tmp/sosreport*FFDC* ; sosreport --batch --tmp-dir "
George Keishing4afd6552023-02-06 03:08:04 -0600179 + "/tmp --label FFDC ; } >/tmp/OS_sosreport.txt 2>&1"
180 ),
Gunnar Millscce185d2016-10-17 17:04:15 -0500181 },
182}
George Keishing671dd662021-05-28 03:26:30 -0500183# Add file name and corresponding command needed for AIX.
184FFDC_OS_AIX_FILE = {
Patrick Williams20f38712022-12-08 06:18:26 -0600185 "OS FILES": {
George Keishing671dd662021-05-28 03:26:30 -0500186 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600187 "OS_errpt.txt": "errpt >/tmp/OS_errpt.txt 2>&1 ; errclear 0;",
188 "OS_processors.txt": "bindprocessor -q >/tmp/OS_processors.txt 2>&1",
George Keishing671dd662021-05-28 03:26:30 -0500189 },
190}
George Keishing19700762020-01-22 12:32:53 -0600191
George Keishinga5bbc302021-10-04 22:30:55 -0500192try:
Patrick Williams20f38712022-12-08 06:18:26 -0600193 redfish_support_trans_state = os.environ.get(
194 "REDFISH_SUPPORT_TRANS_STATE", 0
195 ) or int(
196 BuiltIn().get_variable_value(
197 "${REDFISH_SUPPORT_TRANS_STATE}", default=0
198 )
199 )
George Keishinga5bbc302021-10-04 22:30:55 -0500200except RobotNotRunningError:
201 pass
202
Patrick Williams20f38712022-12-08 06:18:26 -0600203OPENBMC_BASE = "/xyz/openbmc_project/"
204OPENPOWER_BASE = "/org/open_power/"
205ENUMERATE_SENSORS = OPENBMC_BASE + "sensors/enumerate"
206ENUMERATE_INVENTORY = OPENBMC_BASE + "inventory/enumerate"
207ENUMERATE_ELOG = OPENBMC_BASE + "logging/entry/enumerate"
208ENUMERATE_LED = OPENBMC_BASE + "led/enumerate"
209ENUMERATE_SW = OPENBMC_BASE + "software/enumerate"
210ENUMERATE_CONTROL = OPENBMC_BASE + "control/enumerate"
211ENUMERATE_STATE = OPENBMC_BASE + "state/enumerate"
212ENUMERATE_OCC = OPENPOWER_BASE + "/enumerate"
213ENUMERATE_DUMPS = OPENBMC_BASE + "dumps/enumerate"
214ENUMERATE_USER = OPENBMC_BASE + "user/enumerate"
Sweta Potthuria82efd62017-10-18 05:34:59 -0500215
George Keishing671dd662021-05-28 03:26:30 -0500216# Add file name and corresponding Get Request
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500217FFDC_GET_REQUEST = {
Patrick Williams20f38712022-12-08 06:18:26 -0600218 "GET REQUESTS": {
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500219 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600220 "FIRMWARE_list.txt": ENUMERATE_SW,
221 "BMC_sensor_list.txt": ENUMERATE_SENSORS,
222 "BMC_control_list.txt": ENUMERATE_CONTROL,
223 "BMC_inventory.txt": ENUMERATE_INVENTORY,
224 "BMC_elog.txt": ENUMERATE_ELOG,
225 "BMC_led.txt": ENUMERATE_LED,
226 "BMC_state.txt": ENUMERATE_STATE,
227 "OCC_state.txt": ENUMERATE_OCC,
228 "BMC_dumps.txt": ENUMERATE_DUMPS,
229 "BMC_USER.txt": ENUMERATE_USER,
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500230 },
231}
George Keishing8c42bbc2021-09-28 14:52:54 -0500232
George Keishinga5bbc302021-10-04 22:30:55 -0500233# Remove the REST dictionary elements.
234if redfish_support_trans_state == 1:
235 for key in list(FFDC_GET_REQUEST):
236 del FFDC_GET_REQUEST[key]
237
Patrick Williams20f38712022-12-08 06:18:26 -0600238REDFISH_BASE = "/redfish/v1/"
Patrick Williams20f38712022-12-08 06:18:26 -0600239REDFISH_FIRMWARE = REDFISH_BASE + "UpdateService/FirmwareInventory"
George Keishing8c42bbc2021-09-28 14:52:54 -0500240
Yi Huc32434a2024-01-11 17:33:10 -0800241try:
242 REDFISH_SYSTEM_ID = REDFISH_SYSTEM_ID = os.environ.get(
243 "SYSTEM_ID", ""
244 ) or BuiltIn().get_variable_value("${SYSTEM_ID}", default="system")
245
246 REDFISH_ELOG = (
247 REDFISH_BASE
248 + "Systems/"
249 + REDFISH_SYSTEM_ID
250 + "/LogServices/EventLog/Entries"
251 )
252except RobotNotRunningError:
253 REDFISH_ELOG = REDFISH_BASE + "Systems/system/LogServices/EventLog/Entries"
254 pass
255
George Keishing8c42bbc2021-09-28 14:52:54 -0500256# Add file name and corresponding Get Request
257FFDC_GET_REDFISH_REQUEST = {
Patrick Williams20f38712022-12-08 06:18:26 -0600258 "GET REQUESTS": {
George Keishing8c42bbc2021-09-28 14:52:54 -0500259 # File Name Command
Patrick Williams20f38712022-12-08 06:18:26 -0600260 "BMC_redfish_elog.txt": REDFISH_ELOG,
George Keishing8c42bbc2021-09-28 14:52:54 -0500261 },
262}
263
George Keishing69e6f712016-09-12 06:30:09 -0500264# Define your keywords in method/utils and call here
265FFDC_METHOD_CALL = {
Patrick Williams20f38712022-12-08 06:18:26 -0600266 "BMC LOGS": {
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500267 # Description Keyword name
Patrick Williams20f38712022-12-08 06:18:26 -0600268 "Start ffdc cleanup": "BMC FFDC Cleanup",
269 "FFDC Generic Report": "BMC FFDC Manifest",
270 "BMC Specific Files": "BMC FFDC Files",
271 "Get Request FFDC": "BMC FFDC Get Requests",
272 "Get Redfish Request FFDC": "BMC FFDC Get Redfish Requests",
273 "OS FFDC": "OS FFDC Files",
274 "Core Files": "SCP Coredump Files",
275 "SEL Log": "Collect eSEL Log",
276 "Sys Inventory Files": "System Inventory Files",
277 "Dump Files": "SCP Dump Files",
278 "PEL Files": "Collect PEL Log",
279 "Redfish Log": "Enumerate Redfish Resources",
George Keishing4afd6552023-02-06 03:08:04 -0600280 "Firmware Log": (
281 "Enumerate Redfish Resources "
282 + " enum_uri=/redfish/v1/UpdateService/FirmwareInventory "
283 + " file_enum_name=redfish_FIRMWARE_list.txt"
284 ),
Patrick Williams20f38712022-12-08 06:18:26 -0600285 "Redfish OEM Log": "Enumerate Redfish OEM Resources",
286 "End ffdc cleanup": "BMC FFDC Cleanup",
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500287 },
288}
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300289
George Keishing4b4eef72021-04-01 02:31:42 -0500290try:
Patrick Williams20f38712022-12-08 06:18:26 -0600291 platform_arch_type = os.environ.get(
292 "PLATFORM_ARCH_TYPE", ""
293 ) or BuiltIn().get_variable_value("${PLATFORM_ARCH_TYPE}", default="power")
George Keishing4b4eef72021-04-01 02:31:42 -0500294except RobotNotRunningError:
295 pass
296
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300297# Filter the logs based on platform type.
298if platform_arch_type == "x86":
Patrick Williams20f38712022-12-08 06:18:26 -0600299 del FFDC_BMC_FILE["BMC FILES"]["PEL_logs_list.json"]
300 del FFDC_BMC_FILE["BMC FILES"]["PEL_logs_display.json"]
301 del FFDC_METHOD_CALL["BMC LOGS"]["PEL Files"]
Konstantin Aladyshev67880492021-03-20 17:20:57 +0300302
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500303# -----------------------------------------------------------------
George Keishing4346a412016-07-19 11:26:49 -0500304# base class for FFDC default list
Gunnar Mills096cd562018-03-26 10:19:12 -0500305
306
Patrick Williams20f38712022-12-08 06:18:26 -0600307class openbmc_ffdc_list:
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500308 def get_ffdc_bmc_cmd(self, i_type):
309 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500310 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500311 # @brief This method returns the list from the dictionary for cmds
312 # @param i_type: @type string: string index lookup
313 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500314 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500315 """
George Keishing69e6f712016-09-12 06:30:09 -0500316 return FFDC_BMC_CMD[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500317
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500318 def get_ffdc_bmc_file(self, i_type):
319 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500320 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500321 # @brief This method returns the list from the dictionary for scp
322 # @param i_type: @type string: string index lookup
323 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500324 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500325 """
George Keishing69e6f712016-09-12 06:30:09 -0500326 return FFDC_BMC_FILE[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500327
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500328 def get_ffdc_get_request(self, i_type):
329 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500330 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500331 # @brief This method returns the list from the dictionary for scp
332 # @param i_type: @type string: string index lookup
333 # @return List of key pair from the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500334 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500335 """
336 return FFDC_GET_REQUEST[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500337
George Keishing8c42bbc2021-09-28 14:52:54 -0500338 def get_ffdc_get_redfish_request(self, i_type):
339 r"""
340 #######################################################################
341 # @brief This method returns the list from the dictionary for scp
342 # @param i_type: @type string: string index lookup
343 # @return List of key pair from the dictionary
344 #######################################################################
345 """
346 return FFDC_GET_REDFISH_REQUEST[i_type].items()
347
George Keishing69e6f712016-09-12 06:30:09 -0500348 def get_ffdc_cmd_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500349 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500350 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500351 # @brief This method returns the list index from dictionary
352 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500353 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500354 """
George Keishing69e6f712016-09-12 06:30:09 -0500355 return FFDC_BMC_CMD.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500356
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500357 def get_ffdc_get_request_index(self):
358 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500359 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500360 # @brief This method returns the list index from dictionary
361 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500362 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500363 """
364 return FFDC_GET_REQUEST.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500365
George Keishing8c42bbc2021-09-28 14:52:54 -0500366 def get_ffdc_get_redfish_request_index(self):
367 r"""
368 #######################################################################
369 # @brief This method returns the list index from dictionary
370 # @return List of index to the dictionary
371 #######################################################################
372 """
373 return FFDC_GET_REDFISH_REQUEST.keys()
374
George Keishing69e6f712016-09-12 06:30:09 -0500375 def get_ffdc_file_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500376 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500377 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500378 # @brief This method returns the list index from dictionary
379 # @return List of index to the dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500380 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500381 """
George Keishing69e6f712016-09-12 06:30:09 -0500382 return FFDC_BMC_FILE.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500383
George Keishing69e6f712016-09-12 06:30:09 -0500384 def get_ffdc_method_index(self):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500385 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500386 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500387 # @brief This method returns the key pair from the dictionary
388 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500389 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500390 """
George Keishing69e6f712016-09-12 06:30:09 -0500391 return FFDC_METHOD_CALL.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500392
Patrick Williams20f38712022-12-08 06:18:26 -0600393 def get_ffdc_method_desc(self, index):
Michael Walshe844e9a2017-04-20 16:51:10 -0500394 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500395 #######################################################################
Michael Walshe844e9a2017-04-20 16:51:10 -0500396 # @brief This method returns the just the keys from the dictionary.
397 # @return List of ffdc descriptions.
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500398 #######################################################################
Michael Walshe844e9a2017-04-20 16:51:10 -0500399 """
400 return FFDC_METHOD_CALL[index].keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500401
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500402 def get_ffdc_method_call(self, i_type):
403 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500404 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500405 # @brief This method returns the key pair from the dictionary
406 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500407 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500408 """
George Keishing69e6f712016-09-12 06:30:09 -0500409 return FFDC_METHOD_CALL[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500410
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500411 def get_ffdc_os_all_distros_index(self):
412 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500413 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500414 # @brief This method returns the key pair from the dictionary
415 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500416 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500417 """
418 return FFDC_OS_ALL_DISTROS_FILE.keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500419
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500420 def get_ffdc_os_all_distros_call(self, i_type):
421 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500422 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500423 # @brief This method returns the key pair from the dictionary
424 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500425 #######################################################################
Gunnar Mills7e2cda22016-10-11 15:37:34 -0500426 """
427 return FFDC_OS_ALL_DISTROS_FILE[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500428
Gunnar Millscce185d2016-10-17 17:04:15 -0500429 def get_ffdc_os_distro_index(self, distro):
430 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500431 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500432 # @brief This method returns the key pair from the dictionary
433 # @return Index of the method dictionary
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500434 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500435 """
436 distro_file = "FFDC_OS_" + str(distro).upper() + "_FILE"
437 return eval(distro_file).keys()
Gunnar Mills096cd562018-03-26 10:19:12 -0500438
Gunnar Millscce185d2016-10-17 17:04:15 -0500439 def get_ffdc_os_distro_call(self, i_type, distro):
440 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500441 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500442 # @brief This method returns the key pair from the dictionary
443 # @return List of key pair keywords
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500444 #######################################################################
Gunnar Millscce185d2016-10-17 17:04:15 -0500445 """
446 distro_file = "FFDC_OS_" + str(distro).upper() + "_FILE"
447 return eval(distro_file)[i_type].items()
Gunnar Mills096cd562018-03-26 10:19:12 -0500448
George Keishing4346a412016-07-19 11:26:49 -0500449 def get_strip_string(self, i_str):
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500450 r"""
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500451 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500452 # @brief Returns the stripped strings
453 # @param i_str: @type string: string name
454 # @return Remove all special chars and return the string
Joy Onyerikwu004ad3c2018-06-11 16:29:56 -0500455 #######################################################################
Gunnar Millsa812e0f2016-09-29 20:30:03 -0500456 """
Patrick Williams20f38712022-12-08 06:18:26 -0600457 return "".join(e for e in i_str if e.isalnum())
Gunnar Mills096cd562018-03-26 10:19:12 -0500458
George Keishing28da9482017-07-27 13:38:54 -0500459 def get_esel_index(self, esel_list):
460 r"""
461 #######################################################################
462 # @brief Returns the eSEL binary index.
463 # @param esel_ist: @type list: eSEL list.
464 # @return Index of "ESEL=" in the list.
465 #######################################################################
466 """
Patrick Williams20f38712022-12-08 06:18:26 -0600467 index = [i for i, str in enumerate(esel_list) if "ESEL=" in str]
George Keishing28da9482017-07-27 13:38:54 -0500468 return index[0]
Sweta Potthuria82efd62017-10-18 05:34:59 -0500469
470 def get_dump_index(self, dump_list):
471 r"""
472 #######################################################################
473 # @brief Returns the eSEL binary index.
474 # @param esel_ist: @type list: eSEL list.
475 # @return Index of "ESEL=" in the list.
476 #######################################################################
477 """
Patrick Williams20f38712022-12-08 06:18:26 -0600478 index = [i for i, str in enumerate(dump_list) if "DUMP=" in str]
Sweta Potthuria82efd62017-10-18 05:34:59 -0500479 return index[0]