def print_last_boots(): r""" Print the last ten boots done with their time stamps. """ # indent 0, 90 chars wide, linefeed, char is "=" gp.qprint_dashes(0, 90) gp.qprintn("Last 10 boots:\n") for boot_entry in last_ten: grp.rqprint(boot_entry) gp.qprint_dashes(0, 90)
def print_boot_history(boot_history, quiet=None): r""" Print the last ten boots done with their time stamps. Description of argument(s): quiet Only print if this value is 0. This function will search upward in the stack to get the default value. """ quiet = int(gm.dft(quiet, gp.get_stack_var('quiet', 0))) # indent 0, 90 chars wide, linefeed, char is "=" gp.qprint_dashes(0, 90) gp.qprintn("Last 10 boots:\n") for boot_entry in boot_history: gp.qprint(boot_entry) gp.qprint_dashes(0, 90)
def print_defect_report(): r""" Print a defect report. """ # Making deliberate choice to NOT run plug_in_setup(). We don't want # ffdc_prefix updated. rc, shell_rc, failed_plug_in_name = grpi.rprocess_plug_in_packages( call_point='ffdc_report', stop_on_plug_in_failure=0) # At some point I'd like to have the 'Call FFDC Methods' return a list # of files it has collected. In that case, the following "ls" command # would no longer be needed. For now, however, glob shows the files # named in FFDC_LIST_FILE_PATH so I will refrain from printing those # out (so we don't see duplicates in the list). # Get additional header data which may have been created by ffdc plug-ins. # Also, delete the individual header files to cleanup. cmd_buf = "file_list=$(cat " + ffdc_report_list_path + " 2>/dev/null)" +\ " ; [ ! -z \"${file_list}\" ] && cat ${file_list}" +\ " 2>/dev/null ; rm -rf ${file_list} 2>/dev/null || :" shell_rc, more_header_info = gc.cmd_fnc_u(cmd_buf, print_output=0, show_err=0) # Get additional header data which may have been created by ffdc plug-ins. # Also, delete the individual header files to cleanup. cmd_buf = "file_list=$(cat " + ffdc_summary_list_path + " 2>/dev/null)" +\ " ; [ ! -z \"${file_list}\" ] && cat ${file_list}" +\ " 2>/dev/null ; rm -rf ${file_list} 2>/dev/null || :" shell_rc, ffdc_summary_info = gc.cmd_fnc_u(cmd_buf, print_output=0, show_err=0) LOG_PREFIX = BuiltIn().get_variable_value("${LOG_PREFIX}") output = '\n'.join(sorted(glob.glob(LOG_PREFIX + '*'))) try: ffdc_list = open(ffdc_list_file_path, 'r') except IOError: ffdc_list = "" # Open ffdc_file_list for writing. We will write a complete list of # FFDC files to it for possible use by plug-ins like cp_stop_check. ffdc_list_file = open(ffdc_list_file_path, 'w') gp.qprintn() # indent=0, width=90, linefeed=1, char="=" gp.qprint_dashes(0, 90, 1, "=") gp.qprintn("Copy this data to the defect:\n") if len(more_header_info) > 0: gp.qprintn(more_header_info) gp.qpvars(host_name, host_ip, openbmc_nickname, openbmc_host, openbmc_host_name, openbmc_ip, openbmc_username, openbmc_password, os_host, os_host_name, os_ip, os_username, os_password, pdu_host, pdu_host_name, pdu_ip, pdu_username, pdu_password, pdu_slot_no, openbmc_serial_host, openbmc_serial_host_name, openbmc_serial_ip, openbmc_serial_port) gp.qprintn() print_last_boots() gp.qprintn() gp.qprint_var(state) gp.qprintn() gp.qprintn("FFDC data files:") if status_file_path != "": gp.qprintn(status_file_path) ffdc_list_file.write(status_file_path + "\n") gp.qprintn(output) # gp.qprintn(ffdc_list) gp.qprintn() if len(ffdc_summary_info) > 0: gp.qprintn(ffdc_summary_info) gp.qprint_dashes(0, 90, 1, "=") ffdc_list_file.write(output + "\n") ffdc_list_file.close()
def select_boot(): r""" Select a boot test to be run based on our current state and return the chosen boot type. Description of arguments: state The state of the machine. """ global boot_stack gp.qprint_timen("Selecting a boot test.") my_get_state() stack_popped = 0 if len(boot_stack) > 0: stack_popped = 1 gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() skip_boot_printed = 0 while len(boot_stack) > 0: boot_candidate = boot_stack.pop() if stack_mode == 'normal': break else: if st.compare_states(state, boot_table[boot_candidate]['end']): if not skip_boot_printed: gp.qprint_var(stack_mode) gp.qprintn() gp.qprint_timen("Skipping the following boot tests" + " which are unnecessary since their" + " required end states match the" + " current machine state:") skip_boot_printed = 1 gp.qprint_var(boot_candidate) boot_candidate = "" if boot_candidate == "": gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() return boot_candidate if st.compare_states(state, boot_table[boot_candidate]['start']): gp.qprint_timen("The machine state is valid for a '" + boot_candidate + "' boot test.") gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() return boot_candidate else: gp.qprint_timen("The machine state does not match the required" + " starting state for a '" + boot_candidate + "' boot test:") gp.qprint_varx("boot_table[" + boot_candidate + "][start]", boot_table[boot_candidate]['start'], 1) boot_stack.append(boot_candidate) popped_boot = boot_candidate # Loop through your list selecting a boot_candidates boot_candidates = [] for boot_candidate in boot_list: if st.compare_states(state, boot_table[boot_candidate]['start']): if stack_popped: if st.compare_states(boot_table[boot_candidate]['end'], boot_table[popped_boot]['start']): boot_candidates.append(boot_candidate) else: boot_candidates.append(boot_candidate) if len(boot_candidates) == 0: gp.qprint_timen("The user's boot list contained no boot tests" + " which are valid for the current machine state.") boot_candidate = default_power_on if not st.compare_states(state, boot_table[default_power_on]['start']): boot_candidate = default_power_off boot_candidates.append(boot_candidate) gp.qprint_timen("Using default '" + boot_candidate + "' boot type to transition to valid state.") gp.dprint_var(boot_candidates) # Randomly select a boot from the candidate list. boot = random.choice(boot_candidates) return boot
def print_defect_report(ffdc_file_list): r""" Print a defect report. Description of argument(s): ffdc_file_list A list of files which were collected by our ffdc functions. """ # Making deliberate choice to NOT run plug_in_setup(). We don't want # ffdc_prefix updated. rc, shell_rc, failed_plug_in_name = grpi.rprocess_plug_in_packages( call_point='ffdc_report', stop_on_plug_in_failure=0) # Get additional header data which may have been created by ffdc plug-ins. # Also, delete the individual header files to cleanup. cmd_buf = "file_list=$(cat " + ffdc_report_list_path + " 2>/dev/null)" +\ " ; [ ! -z \"${file_list}\" ] && cat ${file_list}" +\ " 2>/dev/null ; rm -rf ${file_list} 2>/dev/null || :" shell_rc, more_header_info = gc.cmd_fnc_u(cmd_buf, print_output=0, show_err=0) # Get additional summary data which may have been created by ffdc plug-ins. # Also, delete the individual header files to cleanup. cmd_buf = "file_list=$(cat " + ffdc_summary_list_path + " 2>/dev/null)" +\ " ; [ ! -z \"${file_list}\" ] && cat ${file_list}" +\ " 2>/dev/null ; rm -rf ${file_list} 2>/dev/null || :" shell_rc, ffdc_summary_info = gc.cmd_fnc_u(cmd_buf, print_output=0, show_err=0) # ffdc_list_file_path contains a list of any ffdc files created by plug- # ins, etc. Read that data into a list. try: plug_in_ffdc_list = \ open(ffdc_list_file_path, 'r').read().rstrip("\n").split("\n") plug_in_ffdc_list = filter(None, plug_in_ffdc_list) except IOError: plug_in_ffdc_list = [] # Combine the files from plug_in_ffdc_list with the ffdc_file_list passed # in. Eliminate duplicates and sort the list. ffdc_file_list = sorted(set(ffdc_file_list + plug_in_ffdc_list)) if status_file_path != "": ffdc_file_list.insert(0, status_file_path) # Convert the list to a printable list. printable_ffdc_file_list = "\n".join(ffdc_file_list) # Open ffdc_file_list for writing. We will write a complete list of # FFDC files to it for possible use by plug-ins like cp_stop_check. ffdc_list_file = open(ffdc_list_file_path, 'w') ffdc_list_file.write(printable_ffdc_file_list + "\n") ffdc_list_file.close() indent = 0 width = 90 linefeed = 1 char = "=" gp.qprintn() gp.qprint_dashes(indent, width, linefeed, char) gp.qprintn("Copy this data to the defect:\n") if len(more_header_info) > 0: gp.qprintn(more_header_info) gp.qpvars(host_name, host_ip, openbmc_nickname, openbmc_host, openbmc_host_name, openbmc_ip, openbmc_username, openbmc_password, os_host, os_host_name, os_ip, os_username, os_password, pdu_host, pdu_host_name, pdu_ip, pdu_username, pdu_password, pdu_slot_no, openbmc_serial_host, openbmc_serial_host_name, openbmc_serial_ip, openbmc_serial_port) gp.qprintn() print_last_boots() gp.qprintn() gp.qprint_var(state) gp.qprintn() gp.qprintn("FFDC data files:") gp.qprintn(printable_ffdc_file_list) gp.qprintn() if len(ffdc_summary_info) > 0: gp.qprintn(ffdc_summary_info) gp.qprint_dashes(indent, width, linefeed, char)
def select_boot(): r""" Select a boot test to be run based on our current state and return the chosen boot type. Description of arguments: state The state of the machine. """ global transitional_boot_selected global boot_stack gp.qprint_timen("Selecting a boot test.") if transitional_boot_selected and not boot_success: prior_boot = next_boot boot_candidate = boot_stack.pop() gp.qprint_timen("The prior '" + next_boot + "' was chosen to" + " transition to a valid state for '" + boot_candidate + "' which was at the top of the boot_stack. Since" + " the '" + next_boot + "' failed, the '" + boot_candidate + "' has been removed from the stack" + " to avoid and endless failure loop.") if len(boot_stack) == 0: return "" my_get_state() valid_state() transitional_boot_selected = False stack_popped = 0 if len(boot_stack) > 0: stack_popped = 1 gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() skip_boot_printed = 0 while len(boot_stack) > 0: boot_candidate = boot_stack.pop() if stack_mode == 'normal': break else: if st.compare_states(state, boot_table[boot_candidate]['end']): if not skip_boot_printed: gp.qprint_var(stack_mode) gp.qprintn() gp.qprint_timen("Skipping the following boot tests" + " which are unnecessary since their" + " required end states match the" + " current machine state:") skip_boot_printed = 1 gp.qprint_var(boot_candidate) boot_candidate = "" if boot_candidate == "": gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() return boot_candidate if st.compare_states(state, boot_table[boot_candidate]['start']): gp.qprint_timen("The machine state is valid for a '" + boot_candidate + "' boot test.") gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() return boot_candidate else: gp.qprint_timen("The machine state does not match the required" + " starting state for a '" + boot_candidate + "' boot test:") gp.qprint_varx("boot_table_start_entry", boot_table[boot_candidate]['start']) boot_stack.append(boot_candidate) transitional_boot_selected = True popped_boot = boot_candidate # Loop through your list selecting a boot_candidates boot_candidates = [] for boot_candidate in boot_list: if st.compare_states(state, boot_table[boot_candidate]['start']): if stack_popped: if st.compare_states(boot_table[boot_candidate]['end'], boot_table[popped_boot]['start']): boot_candidates.append(boot_candidate) else: boot_candidates.append(boot_candidate) if len(boot_candidates) == 0: gp.qprint_timen("The user's boot list contained no boot tests" + " which are valid for the current machine state.") boot_candidate = default_power_on if not st.compare_states(state, boot_table[default_power_on]['start']): boot_candidate = default_power_off boot_candidates.append(boot_candidate) gp.qprint_timen("Using default '" + boot_candidate + "' boot type to transition to valid state.") gp.dprint_var(boot_candidates) # Randomly select a boot from the candidate list. boot = random.choice(boot_candidates) return boot
def print_defect_report(): r""" Print a defect report. """ # Making deliberate choice to NOT run plug_in_setup(). We don't want # ffdc_prefix updated. rc, shell_rc, failed_plug_in_name = grpi.rprocess_plug_in_packages( call_point='ffdc_report', stop_on_plug_in_failure=0) # At some point I'd like to have the 'Call FFDC Methods' return a list # of files it has collected. In that case, the following "ls" command # would no longer be needed. For now, however, glob shows the files # named in FFDC_LIST_FILE_PATH so I will refrain from printing those # out (so we don't see duplicates in the list). # Get additional header data which may have been created by ffdc plug-ins. # Also, delete the individual header files to cleanup. cmd_buf = "file_list=$(cat " + ffdc_report_list_path + " 2>/dev/null)" +\ " ; [ ! -z \"${file_list}\" ] && cat ${file_list}" +\ " 2>/dev/null ; rm -rf ${file_list} 2>/dev/null || :" shell_rc, more_header_info = gc.cmd_fnc_u(cmd_buf, print_output=0, show_err=0) # Get additional header data which may have been created by ffdc plug-ins. # Also, delete the individual header files to cleanup. cmd_buf = "file_list=$(cat " + ffdc_summary_list_path + " 2>/dev/null)" +\ " ; [ ! -z \"${file_list}\" ] && cat ${file_list}" +\ " 2>/dev/null ; rm -rf ${file_list} 2>/dev/null || :" shell_rc, ffdc_summary_info = gc.cmd_fnc_u(cmd_buf, print_output=0, show_err=0) LOG_PREFIX = BuiltIn().get_variable_value("${LOG_PREFIX}") output = '\n'.join(sorted(glob.glob(LOG_PREFIX + '*'))) try: ffdc_list = open(ffdc_list_file_path, 'r') except IOError: ffdc_list = "" # Open ffdc_file_list for writing. We will write a complete list of # FFDC files to it for possible use by plug-ins like cp_stop_check. ffdc_list_file = open(ffdc_list_file_path, 'w') gp.qprintn() # indent=0, width=90, linefeed=1, char="=" gp.qprint_dashes(0, 90, 1, "=") gp.qprintn("Copy this data to the defect:\n") if len(more_header_info) > 0: gp.printn(more_header_info) gp.qpvars(host_name, host_ip, openbmc_nickname, openbmc_host, openbmc_host_name, openbmc_ip, openbmc_username, openbmc_password, os_host, os_host_name, os_ip, os_username, os_password, pdu_host, pdu_host_name, pdu_ip, pdu_username, pdu_password, pdu_slot_no, openbmc_serial_host, openbmc_serial_host_name, openbmc_serial_ip, openbmc_serial_port) gp.qprintn() print_last_boots() gp.qprintn() gp.qprint_var(state) gp.qprintn() gp.qprintn("FFDC data files:") if status_file_path != "": gp.qprintn(status_file_path) ffdc_list_file.write(status_file_path + "\n") gp.qprintn(output) # gp.qprintn(ffdc_list) gp.qprintn() if len(ffdc_summary_info) > 0: gp.printn(ffdc_summary_info) gp.qprint_dashes(0, 90, 1, "=") ffdc_list_file.write(output + "\n") ffdc_list_file.close()
def select_boot(): r""" Select a boot test to be run based on our current state and return the chosen boot type. Description of arguments: state The state of the machine. """ global boot_stack gp.qprint_timen("Selecting a boot test.") my_get_state() stack_popped = 0 if len(boot_stack) > 0: stack_popped = 1 gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() skip_boot_printed = 0 while len(boot_stack) > 0: boot_candidate = boot_stack.pop() if stack_mode == 'normal': break else: if st.compare_states(state, boot_table[boot_candidate]['end']): if not skip_boot_printed: gp.print_var(stack_mode) gp.printn() gp.print_timen("Skipping the following boot tests" + " which are unnecessary since their" + " required end states match the" + " current machine state:") skip_boot_printed = 1 gp.print_var(boot_candidate) boot_candidate = "" if boot_candidate == "": gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() return boot_candidate if st.compare_states(state, boot_table[boot_candidate]['start']): gp.qprint_timen("The machine state is valid for a '" + boot_candidate + "' boot test.") gp.qprint_dashes() gp.qprint_var(boot_stack) gp.qprint_dashes() return boot_candidate else: gp.qprint_timen("The machine state does not match the required" + " starting state for a '" + boot_candidate + "' boot test:") gp.print_varx("boot_table[" + boot_candidate + "][start]", boot_table[boot_candidate]['start'], 1) boot_stack.append(boot_candidate) popped_boot = boot_candidate # Loop through your list selecting a boot_candidates boot_candidates = [] for boot_candidate in boot_list: if st.compare_states(state, boot_table[boot_candidate]['start']): if stack_popped: if st.compare_states(boot_table[boot_candidate]['end'], boot_table[popped_boot]['start']): boot_candidates.append(boot_candidate) else: boot_candidates.append(boot_candidate) if len(boot_candidates) == 0: gp.qprint_timen("The user's boot list contained no boot tests" + " which are valid for the current machine state.") boot_candidate = default_power_on if not st.compare_states(state, boot_table[default_power_on]['start']): boot_candidate = default_power_off boot_candidates.append(boot_candidate) gp.qprint_timen("Using default '" + boot_candidate + "' boot type to transition to valid state.") gp.dprint_var(boot_candidates) # Randomly select a boot from the candidate list. boot = random.choice(boot_candidates) return boot