| George Keishing | e7e9171 | 2021-09-03 11:28:44 -0500 | [diff] [blame] | 1 | #!/usr/bin/env python3 | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 2 |  | 
|  | 3 | r""" | 
|  | 4 | This file contains functions which are useful for processing BMC dumps. | 
|  | 5 | """ | 
|  | 6 |  | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 7 | import imp | 
| Michael Walsh | 4f3ce17 | 2017-10-19 17:28:49 -0500 | [diff] [blame] | 8 | import os | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 9 | import sys | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 10 |  | 
|  | 11 | import bmc_ssh_utils as bsu | 
|  | 12 | import gen_misc as gm | 
|  | 13 | import gen_print as gp | 
|  | 14 | import gen_robot_keyword as grk | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 15 | from robot.libraries.BuiltIn import BuiltIn | 
|  | 16 |  | 
|  | 17 | base_path = ( | 
|  | 18 | os.path.dirname(os.path.dirname(imp.find_module("gen_robot_print")[1])) | 
|  | 19 | + os.sep | 
|  | 20 | ) | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 21 | sys.path.append(base_path + "data/") | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 22 | import variables as var  # NOQA | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 23 |  | 
|  | 24 |  | 
|  | 25 | def get_dump_dict(quiet=None): | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 26 | r""" | 
|  | 27 | Get dump information and return as an ordered dictionary where the keys | 
|  | 28 | are the dump IDs and the values are the full path names of the dumps. | 
|  | 29 |  | 
|  | 30 | Example robot program call: | 
|  | 31 |  | 
|  | 32 | ${dump_dict}=  Get Dump Dict | 
| Michael Walsh | 39c0051 | 2019-07-17 10:54:06 -0500 | [diff] [blame] | 33 | Rprint Vars  dump_dict | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 34 |  | 
|  | 35 | Example output: | 
|  | 36 |  | 
|  | 37 | dump_dict: | 
| Joy Onyerikwu | 004ad3c | 2018-06-11 16:29:56 -0500 | [diff] [blame] | 38 | [1]: | 
|  | 39 | /var/lib/phosphor-debug-collector/dumps/1/obmcdump_1_1508255216.tar.xz | 
|  | 40 | [2]: | 
|  | 41 | /var/lib/phosphor-debug-collector/dumps/2/obmcdump_2_1508255245.tar.xz | 
|  | 42 | [3]: | 
|  | 43 | /var/lib/phosphor-debug-collector/dumps/3/obmcdump_3_1508255267.tar.xz | 
|  | 44 | [4]: | 
|  | 45 | /var/lib/phosphor-debug-collector/dumps/4/obmcdump_4_1508255283.tar.xz | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 46 |  | 
|  | 47 | Description of argument(s): | 
|  | 48 | quiet                           If quiet is set to 1, this function will | 
|  | 49 | NOT write status messages to stdout. | 
|  | 50 | """ | 
|  | 51 |  | 
|  | 52 | quiet = int(gp.get_var_value(quiet, 1)) | 
| George Keishing | bd8ec92 | 2022-03-31 13:39:35 -0500 | [diff] [blame] | 53 | cmd_buf = "find /var/lib/phosphor-debug-collector/ -maxdepth 4 -type f" | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 54 | output, stderr, rc = bsu.bmc_execute_command(cmd_buf, quiet=quiet) | 
|  | 55 |  | 
| George Keishing | bd8ec92 | 2022-03-31 13:39:35 -0500 | [diff] [blame] | 56 | BuiltIn().log_to_console(output) | 
|  | 57 | return output.split("\n") | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 58 |  | 
|  | 59 |  | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 60 | def valid_dump(dump_id, dump_dict=None, quiet=None): | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 61 | r""" | 
|  | 62 | Verify that dump_id is a valid.  If it is not valid, issue robot failure | 
|  | 63 | message. | 
|  | 64 |  | 
|  | 65 | A dump is valid if the indicated dump_id refers to an existing dump with a | 
|  | 66 | valid associated dump file. | 
|  | 67 |  | 
|  | 68 | Description of argument(s): | 
|  | 69 | dump_id                         A dump ID (e.g. "1", "2", etc.) | 
|  | 70 | dump_dict                       A dump dictionary such as the one returned | 
|  | 71 | by get_dump_dict.  If this value is None, | 
|  | 72 | this function will call get_dump_dict on | 
|  | 73 | the caller's behalf. | 
|  | 74 | quiet                           If quiet is set to 1, this function will | 
|  | 75 | NOT write status messages to stdout. | 
|  | 76 | """ | 
|  | 77 |  | 
|  | 78 | if dump_dict is None: | 
|  | 79 | dump_dict = get_dump_dict(quiet=quiet) | 
|  | 80 |  | 
|  | 81 | if dump_id not in dump_dict: | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 82 | message = ( | 
|  | 83 | "The specified dump ID was not found among the existing" | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 84 | + " dumps:\n" | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 85 | ) | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 86 | message += gp.sprint_var(dump_id) | 
|  | 87 | message += gp.sprint_var(dump_dict) | 
|  | 88 | BuiltIn().fail(gp.sprint_error(message)) | 
|  | 89 |  | 
|  | 90 | if not dump_dict[dump_id].endswith("tar.xz"): | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 91 | message = ( | 
|  | 92 | 'There is no "tar.xz" file associated with the given' | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 93 | + " dump_id:\n" | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 94 | ) | 
| Michael Walsh | e11a136 | 2017-10-19 15:35:26 -0500 | [diff] [blame] | 95 | message += gp.sprint_var(dump_id) | 
|  | 96 | dump_file_path = dump_dict[dump_id] | 
|  | 97 | message += gp.sprint_var(dump_file_path) | 
|  | 98 | BuiltIn().fail(gp.sprint_error(message)) | 
| Michael Walsh | 4f3ce17 | 2017-10-19 17:28:49 -0500 | [diff] [blame] | 99 |  | 
|  | 100 |  | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 101 | def scp_dumps(targ_dir_path, targ_file_prefix="", dump_dict=None, quiet=None): | 
| Michael Walsh | 4f3ce17 | 2017-10-19 17:28:49 -0500 | [diff] [blame] | 102 | r""" | 
|  | 103 | SCP all dumps from the BMC to the indicated directory on the local system | 
|  | 104 | and return a list of the new files. | 
|  | 105 |  | 
|  | 106 | Description of argument(s): | 
|  | 107 | targ_dir_path                   The path of the directory to receive the | 
|  | 108 | dump files. | 
| George Keishing | e16f158 | 2022-12-15 07:32:21 -0600 | [diff] [blame] | 109 | targ_file_prefix                Prefix which will be prepended to each | 
| Michael Walsh | 4f3ce17 | 2017-10-19 17:28:49 -0500 | [diff] [blame] | 110 | target file's name. | 
|  | 111 | dump_dict                       A dump dictionary such as the one returned | 
|  | 112 | by get_dump_dict.  If this value is None, | 
|  | 113 | this function will call get_dump_dict on | 
|  | 114 | the caller's behalf. | 
|  | 115 | quiet                           If quiet is set to 1, this function will | 
|  | 116 | NOT write status messages to stdout. | 
|  | 117 | """ | 
|  | 118 |  | 
|  | 119 | targ_dir_path = gm.add_trailing_slash(targ_dir_path) | 
|  | 120 |  | 
|  | 121 | if dump_dict is None: | 
| George Keishing | bd8ec92 | 2022-03-31 13:39:35 -0500 | [diff] [blame] | 122 | dump_list = get_dump_dict(quiet=quiet) | 
| Michael Walsh | 4f3ce17 | 2017-10-19 17:28:49 -0500 | [diff] [blame] | 123 |  | 
|  | 124 | status, ret_values = grk.run_key("Open Connection for SCP", quiet=quiet) | 
|  | 125 |  | 
|  | 126 | dump_file_list = [] | 
| George Keishing | bd8ec92 | 2022-03-31 13:39:35 -0500 | [diff] [blame] | 127 | for file_path in dump_list: | 
| Patrick Williams | 20f3871 | 2022-12-08 06:18:26 -0600 | [diff] [blame] | 128 | targ_file_path = ( | 
|  | 129 | targ_dir_path + targ_file_prefix + os.path.basename(file_path) | 
|  | 130 | ) | 
|  | 131 | status, ret_values = grk.run_key( | 
|  | 132 | "scp.Get File  " + file_path + "  " + targ_file_path, quiet=quiet | 
|  | 133 | ) | 
| George Keishing | 1165a02 | 2021-05-19 06:23:13 -0500 | [diff] [blame] | 134 | dump_file_list.append(targ_file_path) | 
|  | 135 |  | 
|  | 136 | return dump_file_list |