From 97b635d05fdc7e4afb7164ea60de1f81f0e14849 Mon Sep 17 00:00:00 2001 From: Michal Bocek Date: Mon, 25 Nov 2024 22:28:33 +0100 Subject: [PATCH] Format messages for consistency - no full stop at the end of a report message title - no word please (technical writers' rule) - boot loader => bootloader - fix typos - add missing context where messages are too short and vague - make TASK tense consistent - ensure each Action has a TASK level log message - ensure every Action prints what it's done - add unit tests to lines reported by caplog as uncovered --- convert2rhel/actions/__init__.py | 6 +- .../conversion/list_non_red_hat_pkgs_left.py | 2 +- .../conversion/preserve_only_rhel_kernel.py | 60 ++++++++++------- .../actions/conversion/set_efi_config.py | 2 +- .../actions/post_conversion/hostmetering.py | 25 +++---- .../modified_rpm_files_diff.py | 6 +- .../actions/post_conversion/remove_tmp_dir.py | 4 +- .../actions/post_conversion/update_grub.py | 2 +- .../actions/pre_ponr_changes/backup_system.py | 18 +++-- .../custom_repos_are_valid.py | 7 +- .../pre_ponr_changes/handle_packages.py | 15 +++-- .../pre_ponr_changes/kernel_modules.py | 4 +- .../actions/pre_ponr_changes/subscription.py | 12 ++-- .../actions/pre_ponr_changes/transaction.py | 2 +- .../check_firewalld_availability.py | 6 +- .../system_checks/convert2rhel_latest.py | 12 ++-- convert2rhel/actions/system_checks/dbus.py | 8 +-- .../system_checks/duplicate_packages.py | 2 +- convert2rhel/actions/system_checks/efi.py | 2 +- convert2rhel/actions/system_checks/els.py | 10 ++- convert2rhel/actions/system_checks/eus.py | 22 ++++++- .../actions/system_checks/grub_validity.py | 15 +++-- .../system_checks/is_loaded_kernel_latest.py | 12 ++-- .../actions/system_checks/package_updates.py | 8 +-- .../system_checks/rhel_compatible_kernel.py | 2 +- .../actions/system_checks/tainted_kmods.py | 8 +-- convert2rhel/backup/__init__.py | 2 +- convert2rhel/backup/certs.py | 6 +- convert2rhel/backup/files.py | 8 +-- convert2rhel/backup/packages.py | 18 ++--- convert2rhel/backup/subscription.py | 6 +- convert2rhel/main.py | 4 +- convert2rhel/pkghandler.py | 5 +- .../pkgmanager/handlers/dnf/__init__.py | 14 ++-- .../pkgmanager/handlers/yum/__init__.py | 14 ++-- convert2rhel/redhatrelease.py | 2 +- convert2rhel/repo.py | 2 +- convert2rhel/subscription.py | 32 ++++----- convert2rhel/systeminfo.py | 2 +- convert2rhel/toolopts/__init__.py | 4 +- convert2rhel/toolopts/config.py | 6 +- .../preserve_only_rhel_kernel_test.py | 16 ++--- .../post_conversion/hostmetering_test.py | 66 +++++++++---------- .../modified_rpm_files_diff_test.py | 4 +- .../post_conversion/remove_tmp_dir_test.py | 2 +- .../post_conversion/update_grub_test.py | 2 +- .../pre_ponr_changes/backup_system_test.py | 18 ++--- .../custom_repos_are_valid_test.py | 7 +- .../pre_ponr_changes/handle_packages_test.py | 8 +-- .../pre_ponr_changes/kernel_modules_test.py | 6 +- .../pre_ponr_changes/subscription_test.py | 2 +- .../check_firewalld_availability_test.py | 16 ++++- .../system_checks/convert2rhel_latest_test.py | 18 +++-- .../actions/system_checks/dbus_test.py | 6 +- .../actions/system_checks/efi_test.py | 2 +- .../actions/system_checks/els_test.py | 10 ++- .../actions/system_checks/eus_test.py | 50 +++++++++----- .../system_checks/grub_validity_test.py | 35 ++++++---- .../is_loaded_kernel_latest_test.py | 38 +++++------ .../system_checks/package_updates_test.py | 8 +-- .../rhel_compatible_kernel_test.py | 2 +- .../system_checks/tainted_kmods_test.py | 8 +-- convert2rhel/unit_tests/backup/files_test.py | 8 +-- .../unit_tests/backup/packages_test.py | 4 +- .../unit_tests/backup/subscription_test.py | 2 +- convert2rhel/unit_tests/cli_test.py | 8 +-- convert2rhel/unit_tests/main_test.py | 19 ++++-- .../pkgmanager/handlers/dnf/dnf_test.py | 10 +-- .../pkgmanager/handlers/yum/yum_test.py | 6 +- convert2rhel/unit_tests/subscription_test.py | 4 +- .../unit_tests/toolopts/toolopts_test.py | 8 +-- convert2rhel/unit_tests/utils/utils_test.py | 6 +- convert2rhel/utils/__init__.py | 22 ++++--- convert2rhel/utils/subscription.py | 2 +- .../test_basic_sanity_checks.py | 2 +- .../config-file/test_config_file.py | 4 +- .../cve-2022-1662/test_cve-2022-1662.py | 4 +- ...est_enabled_repositories_after_analysis.py | 2 +- .../grub/test_invalid_changed_to_grub.py | 6 +- .../kernel/test_kernel_check_verification.py | 3 +- .../test_single_yum_transaction_validation.py | 8 +-- .../test_sub_man_pre_register.py | 4 +- .../test_sub_man_rollback.py | 2 +- .../test_yum_conf_exclude_packages.py | 2 +- .../test_httpd_package_transaction_error.py | 2 +- 85 files changed, 470 insertions(+), 389 deletions(-) diff --git a/convert2rhel/actions/__init__.py b/convert2rhel/actions/__init__.py index 880624a88a..1d8ad27740 100644 --- a/convert2rhel/actions/__init__.py +++ b/convert2rhel/actions/__init__.py @@ -559,7 +559,7 @@ def run(self, successes=None, failures=None, skips=None): title="Skipped action", description="This action was skipped due to another action failing.", diagnosis=diagnosis, - remediations="Please ensure that the {} check passes so that this Action can evaluate your system".format( + remediations="Ensure that the {} check passes so that this Action can evaluate your system".format( utils.format_sequence_as_message(failed_deps) ), ) @@ -586,7 +586,7 @@ def run(self, successes=None, failures=None, skips=None): # Categorize the results if action.result.level <= STATUS_CODE["WARNING"]: - logger.info("{} has succeeded".format(action.id)) + logger.info("The {} action has succeeded.".format(action.id)) successes.append(action) if action.result.level > STATUS_CODE["WARNING"]: @@ -742,7 +742,7 @@ def run_pre_actions(): # When we call check_dependencies() or run() on the first Stage # (system_checks), it will operate on the first Stage and then recursively # call check_dependencies() or run() on the next_stage. - pre_ponr_changes = Stage("pre_ponr_changes", "Making recoverable changes") + pre_ponr_changes = Stage("pre_ponr_changes", "Make recoverable changes") system_checks = Stage("system_checks", "Check whether system is ready for conversion", next_stage=pre_ponr_changes) try: diff --git a/convert2rhel/actions/conversion/list_non_red_hat_pkgs_left.py b/convert2rhel/actions/conversion/list_non_red_hat_pkgs_left.py index 5c4d4a934a..e8054bcbd0 100644 --- a/convert2rhel/actions/conversion/list_non_red_hat_pkgs_left.py +++ b/convert2rhel/actions/conversion/list_non_red_hat_pkgs_left.py @@ -34,7 +34,7 @@ def run(self): super(ListNonRedHatPkgsLeft, self).run() loggerinst.task("List remaining non-Red Hat packages") - loggerinst.info("Listing packages not signed by Red Hat") + loggerinst.info("Listing packages not signed by Red Hat.") non_red_hat_pkgs = get_installed_pkgs_w_different_key_id(system_info.key_ids_rhel) if not non_red_hat_pkgs: loggerinst.info("All packages are now signed by Red Hat.") diff --git a/convert2rhel/actions/conversion/preserve_only_rhel_kernel.py b/convert2rhel/actions/conversion/preserve_only_rhel_kernel.py index bf252e4962..7cf33d8041 100644 --- a/convert2rhel/actions/conversion/preserve_only_rhel_kernel.py +++ b/convert2rhel/actions/conversion/preserve_only_rhel_kernel.py @@ -36,7 +36,7 @@ def run(self): non-RHEL kernel(s) conflicted with the available RHEL kernels. """ super(InstallRhelKernel, self).run() - loggerinst.info("Verifying that RHEL kernel has been installed") + loggerinst.task("Verify RHEL kernel installation") rhel_kernels = pkghandler.get_installed_pkgs_by_key_id(system_info.key_ids_rhel, name="kernel") @@ -68,8 +68,8 @@ class FixInvalidGrub2Entries(actions.Action): def run(self): """ - On systems derived from RHEL 8 and later, /etc/machine-id is being used to identify grub2 boot loader entries per - the Boot Loader Specification. + On systems derived from RHEL 8 and later, /etc/machine-id is being used to identify grub2 bootloader entries per + the bootloader Specification. However, at the time of executing convert2rhel, the current machine-id can be different from the machine-id from the time when the kernels were installed. If that happens: - convert2rhel installs the RHEL kernel, but it's not set as default @@ -79,18 +79,18 @@ def run(self): """ super(FixInvalidGrub2Entries, self).run() + loggerinst.task("Fix GRUB2 bootloader entries") if system_info.version.major < 8: # Applicable only on systems derived from RHEL 8 and later, and systems using GRUB2 (s390x uses zipl) + loggerinst.info("Skipped. Only relevant to RHEL 8 and newer.") return - loggerinst.info("Fixing GRUB boot loader entries.") - machine_id = utils.get_file_content("/etc/machine-id").strip() boot_entries = glob.glob("/boot/loader/entries/*.conf") for entry in boot_entries: - # The boot loader entries in /boot/loader/entries/-.conf + # The bootloader entries in /boot/loader/entries/-.conf if machine_id not in os.path.basename(entry): - loggerinst.debug("Removing boot entry {}".format(entry)) + loggerinst.debug("Removing boot entry {}.".format(entry)) os.remove(entry) # Removing a boot entry that used to be the default makes grubby to choose a different entry as default, @@ -99,24 +99,24 @@ def run(self): if ret_code: # Not setting the default entry shouldn't be a deal breaker and the reason to stop the conversions, # grub should pick one entry in any case. - description = "Couldn't get the default GRUB2 boot loader entry:\n{}".format(output) + description = "Couldn't get the default GRUB2 bootloader entry:\n{}".format(output) loggerinst.warning(description) self.add_message( level="WARNING", id="UNABLE_TO_GET_GRUB2_BOOT_LOADER_ENTRY", - title="Unable to get the GRUB2 boot loader entry", + title="Unable to get the GRUB2 bootloader entry", description=description, ) return - loggerinst.debug("Setting RHEL kernel {} as the default boot loader entry.".format(output.strip())) + loggerinst.debug("Setting RHEL kernel {} as the default bootloader entry.".format(output.strip())) output, ret_code = utils.run_subprocess(["/usr/sbin/grubby", "--set-default", output.strip()]) if ret_code: - description = "Couldn't set the default GRUB2 boot loader entry:\n{}".format(output) + description = "Couldn't set the default GRUB2 bootloader entry:\n{}".format(output) loggerinst.warning(description) self.add_message( level="WARNING", id="UNABLE_TO_SET_GRUB2_BOOT_LOADER_ENTRY", - title="Unable to set the GRUB2 boot loader entry", + title="Unable to set the GRUB2 bootloader entry", description=description, ) @@ -134,7 +134,7 @@ def run(self): """ super(FixDefaultKernel, self).run() - loggerinst.info("Checking for incorrect boot kernel") + loggerinst.task("Check for default boot kernel in /etc/sysconfig/kernel") kernel_sys_cfg = utils.get_file_content("/etc/sysconfig/kernel") possible_kernels = ["kernel-uek", "kernel-plus"] @@ -143,22 +143,29 @@ def run(self): None, ) if kernel_to_change: - description = "Detected leftover boot kernel, changing to RHEL kernel" - loggerinst.warning(description) + diagnosis = "Detected default boot kernel {} in /etc/sysconfig/kernel.".format(kernel_to_change) + # need to change to "kernel" in rhel7 and "kernel-core" in rhel8 + new_kernel_str = "DEFAULTKERNEL=" + ("kernel" if system_info.version.major == 7 else "kernel-core") + loggerinst.warning(diagnosis) self.add_message( level="WARNING", id="LEFTOVER_BOOT_KERNEL_DETECTED", - title="Leftover boot kernel detected", - description=description, + title="Leftover default boot kernel detected", + diagnosis=diagnosis, + description="Some systems have the default boot kernel in /etc/sysconfig/kernel set to a distribution" + " specific kernel even after such a kernel is uninstalled. We have changed it to {}.".format( + new_kernel_str + ), ) - # need to change to "kernel" in rhel7 and "kernel-core" in rhel8 - new_kernel_str = "DEFAULTKERNEL=" + ("kernel" if system_info.version.major == 7 else "kernel-core") - kernel_sys_cfg = kernel_sys_cfg.replace("DEFAULTKERNEL=" + kernel_to_change, new_kernel_str) utils.store_content_to_file("/etc/sysconfig/kernel", kernel_sys_cfg) - loggerinst.info("Boot kernel {} was changed to {}".format(kernel_to_change, new_kernel_str)) + loggerinst.info( + "Default boot kernel {} was changed to {} in /etc/sysconfig/kernel.".format( + kernel_to_change, new_kernel_str + ) + ) else: - loggerinst.debug("Boot kernel validated.") + loggerinst.debug("The default boot kernel is correct.") class KernelPkgsInstall(actions.Action): @@ -169,18 +176,20 @@ def run(self): """Remove non-RHEL kernels.""" super(KernelPkgsInstall, self).run() + loggerinst.task("Remove non-RHEL kernels") + kernel_pkgs_to_install = self.remove_non_rhel_kernels() if kernel_pkgs_to_install: self.install_additional_rhel_kernel_pkgs(kernel_pkgs_to_install) def remove_non_rhel_kernels(self): - loggerinst.info("Searching for non-RHEL kernels ...") + loggerinst.info("Searching for non-RHEL kernels.") non_rhel_kernels = pkghandler.get_installed_pkgs_w_different_key_id(system_info.key_ids_rhel, "kernel*") if not non_rhel_kernels: loggerinst.info("None found.") return None - loggerinst.info("Removing non-RHEL kernels\n") + loggerinst.info("Removing detected non-RHEL kernels.\n") pkghandler.print_pkg_info(non_rhel_kernels) pkgs_to_remove = [pkghandler.get_pkg_nvra(pkg) for pkg in non_rhel_kernels] utils.remove_pkgs(pkgs_to_remove) @@ -198,7 +207,7 @@ def install_additional_rhel_kernel_pkgs(self, additional_pkgs): pkg_names = [p.nevra.name.replace(ol_kernel_ext, "", 1) for p in additional_pkgs] for name in set(pkg_names): if name != "kernel": - loggerinst.info("Installing RHEL {}".format(name)) + loggerinst.info("Installing RHEL {}.".format(name)) pkgmanager.call_yum_cmd("install", args=[name]) @@ -217,4 +226,5 @@ def run(self): """ super(UpdateKernel, self).run() + loggerinst.task("Update RHEL kernel") pkghandler.update_rhel_kernel() diff --git a/convert2rhel/actions/conversion/set_efi_config.py b/convert2rhel/actions/conversion/set_efi_config.py index 280644be53..ddf92eef8a 100644 --- a/convert2rhel/actions/conversion/set_efi_config.py +++ b/convert2rhel/actions/conversion/set_efi_config.py @@ -169,7 +169,7 @@ def run(self): ) continue - logger.info("Moving '{}' to '{}'".format(src_file, dst_file)) + logger.info("Moving '{}' to '{}'.".format(src_file, dst_file)) try: shutil.move(src_file, dst_file) diff --git a/convert2rhel/actions/post_conversion/hostmetering.py b/convert2rhel/actions/post_conversion/hostmetering.py index 5fad03c582..ae4fa79c4d 100644 --- a/convert2rhel/actions/post_conversion/hostmetering.py +++ b/convert2rhel/actions/post_conversion/hostmetering.py @@ -69,8 +69,8 @@ def run(self): self.add_message( level="WARNING", id="INSTALL_HOST_METERING_FAILURE", - title="Failed to install host metering package.", - description="When installing host metering package an error occurred meaning we can't" + title="Failed to install the host-metering package", + description="When installing the host-metering package an error occurred meaning we can't" " enable host metering on the system.", diagnosis="`yum install host-metering` command returned {ret_install} with message {output}".format( ret_install=ret_install, output=output @@ -89,9 +89,9 @@ def run(self): self.add_message( level="WARNING", id="CONFIGURE_HOST_METERING_FAILURE", - title="Failed to enable and start host metering service.", + title="Failed to enable and start the host metering service", description="The host metering service failed to start" - " successfully and won't be able to keep track.", + " successfully and won't be able to report on the use of the system for the billing purposes.", diagnosis="Command {command} failed with {error_message}".format( command=command, error_message=error_message ), @@ -109,7 +109,7 @@ def run(self): self.set_result( level="ERROR", id="HOST_METERING_NOT_RUNNING", - title="Host metering service is not running.", + title="Host metering service is not running", description="host-metering.service is not running.", remediations="You can try to start the service manually" " by running following command:\n" @@ -126,7 +126,7 @@ def _check_host_metering_configuration(self): :rtype: bool """ if tool_opts.configure_host_metering is None: - logger.debug("You have not enabled configuration of host metering. Skipping it.") + logger.info("You have not enabled configuration of host metering. Skipping it.") return False if tool_opts.configure_host_metering not in ("force", "auto"): @@ -152,19 +152,22 @@ def _check_host_metering_configuration(self): if tool_opts.configure_host_metering == "force": logger.warning( "You've set the host metering setting to 'force'." - " Please note that this option is mainly used for testing and will configure host-metering unconditionally. " - " For generic usage please use the 'auto' option." + " Note that this option is mainly used for testing and will configure host-metering unconditionally. " + " For generic usage use the 'auto' option." ) self.add_message( level="WARNING", id="FORCED_CONFIGURE_HOST_METERING", title="Configuration of host metering set to 'force'", - description="Please note that this option is mainly used for testing and" + description="Note that this option is mainly used for testing and" " will configure host-metering unconditionally." - " For generic usage please use the 'auto' option.", + " For generic usage use the 'auto' option.", ) elif tool_opts.configure_host_metering == "auto": - logger.debug("Automatic detection of host hyperscaler and configuration.") + logger.debug( + "Configuration of host metering set to 'auto' - host-metering will be enabled based on" + " a detected hyperscaler." + ) return True diff --git a/convert2rhel/actions/post_conversion/modified_rpm_files_diff.py b/convert2rhel/actions/post_conversion/modified_rpm_files_diff.py index a458817f57..2b98edf4e9 100644 --- a/convert2rhel/actions/post_conversion/modified_rpm_files_diff.py +++ b/convert2rhel/actions/post_conversion/modified_rpm_files_diff.py @@ -46,7 +46,7 @@ def run(self): self.add_message( level="INFO", id="SKIPPED_MODIFIED_RPM_FILES_DIFF", - title="Skipped comparison of 'rpm -Va' output from before and after the conversion.", + title="Skipped comparison of 'rpm -Va' output from before and after the conversion", description="Comparison of 'rpm -Va' output was not performed due to missing output " "of the 'rpm -Va' run before the conversion.", diagnosis="This is caused mainly by using '--no-rpm-va' argument for convert2rhel.", @@ -76,8 +76,8 @@ def run(self): self.add_message( level="INFO", id="FOUND_MODIFIED_RPM_FILES", - title="Modified rpm files from before and after the conversion were found.", - description="Comparison of modified rpm files from before and after " "the conversion: \n{}".format( + title="Modified rpm files from before and after the conversion were found", + description="Comparison of modified rpm files from before and after the conversion: \n{}".format( modified_rpm_files_diff ), ) diff --git a/convert2rhel/actions/post_conversion/remove_tmp_dir.py b/convert2rhel/actions/post_conversion/remove_tmp_dir.py index d89088572b..d539a4245b 100644 --- a/convert2rhel/actions/post_conversion/remove_tmp_dir.py +++ b/convert2rhel/actions/post_conversion/remove_tmp_dir.py @@ -45,7 +45,7 @@ def run(self): try: shutil.rmtree(self.tmp_dir) - loggerinst.info("Temporary folder {} removed".format(self.tmp_dir)) + loggerinst.info("Temporary folder {} removed.".format(self.tmp_dir)) except OSError as exc: # We want run() to be idempotent, so do nothing silently if # the path doesn't exist. @@ -61,6 +61,6 @@ def run(self): self.add_message( level="WARNING", id="UNSUCCESSFUL_REMOVE_TMP_DIR", - title="Temporary folder {tmp_dir} wasn't removed.".format(tmp_dir=self.tmp_dir), + title="Temporary folder {tmp_dir} wasn't removed".format(tmp_dir=self.tmp_dir), description=warning_message, ) diff --git a/convert2rhel/actions/post_conversion/update_grub.py b/convert2rhel/actions/post_conversion/update_grub.py index 76c24e452c..30ba10affa 100644 --- a/convert2rhel/actions/post_conversion/update_grub.py +++ b/convert2rhel/actions/post_conversion/update_grub.py @@ -77,7 +77,7 @@ def run(self): level="ERROR", id="FAILED_TO_IDENTIFY_GRUB2_BLOCK_DEVICE", title="Failed to identify GRUB2 block device", - description="The block device could not be identified, please look at the diagnosis " + description="The block device could not be identified. Look at the diagnosis " "for more information.", diagnosis=str(e), ) diff --git a/convert2rhel/actions/pre_ponr_changes/backup_system.py b/convert2rhel/actions/pre_ponr_changes/backup_system.py index a33bd62c38..9adc94ea24 100644 --- a/convert2rhel/actions/pre_ponr_changes/backup_system.py +++ b/convert2rhel/actions/pre_ponr_changes/backup_system.py @@ -51,8 +51,8 @@ class BackupRedhatRelease(actions.Action): id = "BACKUP_REDHAT_RELEASE" def run(self): - """Backup redhat release file before starting conversion process""" - logger.task("Backup Redhat Release Files") + """Back up redhat release file before starting conversion process""" + logger.task("Back up redhat-release files") super(BackupRedhatRelease, self).run() @@ -79,7 +79,7 @@ class BackupRepository(actions.Action): def run(self): """Backup .repo files in /etc/yum.repos.d/ so the repositories can be restored on rollback.""" - logger.task("Backup Repository Files") + logger.task("Back up repository files") super(BackupRepository, self).run() @@ -105,7 +105,7 @@ class BackupYumVariables(actions.Action): def run(self): """Backup varsdir folder in /etc/{yum,dnf}/vars so the variables can be restored on rollback.""" - logger.task("Backup variables") + logger.task("Back up variables") super(BackupYumVariables, self).run() @@ -146,7 +146,7 @@ def run(self): """Backup changed package files""" super(BackupPackageFiles, self).run() - logger.task("Backup package files") + logger.task("Back up package files") package_files_changes = self._get_changed_package_files() @@ -178,7 +178,6 @@ def _get_changed_package_files(self): """Get the output from rpm -Va command from during resolving system info to get changes made to package files. - :return dict: Return them as a list of dict, for example: [{"status":"S5T", "file_type":"c", "path":"/etc/yum.repos.d/CentOS-Linux-AppStream.repo"}] """ @@ -199,10 +198,9 @@ def _get_changed_package_files(self): # Return empty list results in no backup of the files return data else: - # The file should be there - # If missing conversion is in unknown state + # The file should be there. If missing, the conversion is in an unknown state. logger.warning("Error({}): {}".format(err.errno, err.strerror)) - logger.critical("Missing file {rpm_va_output} in it's location".format(rpm_va_output=path)) + logger.critical("The file {rpm_va_output} is missing.".format(rpm_va_output=path)) lines = output.strip().split("\n") for line in lines: @@ -220,7 +218,7 @@ def _parse_line(self, line): if not match: # line not matching the regex if line.strip() != "": # Line is not empty string - logger.debug("Skipping invalid output {}".format(line)) + logger.debug("Skipping invalid output: {}".format(line)) return {"status": None, "file_type": None, "path": None} line = line.split() diff --git a/convert2rhel/actions/pre_ponr_changes/custom_repos_are_valid.py b/convert2rhel/actions/pre_ponr_changes/custom_repos_are_valid.py index ef68bbea8d..bfba4f4272 100644 --- a/convert2rhel/actions/pre_ponr_changes/custom_repos_are_valid.py +++ b/convert2rhel/actions/pre_ponr_changes/custom_repos_are_valid.py @@ -39,7 +39,10 @@ def run(self): logger.task("Check if --enablerepo repositories are accessible") if not tool_opts.enablerepo: - logger.info("Did not perform the check of repositories due to the use of RHSM for the conversion.") + logger.info( + "No repositories passed through --enablerepo. Skipping the check verifying the" + " accessibility of the repositories." + ) return output, ret_code = call_yum_cmd( @@ -53,7 +56,7 @@ def run(self): id="UNABLE_TO_ACCESS_REPOSITORIES", title="Unable to access repositories", description="Access could not be made to the custom repositories.", - diagnosis="Unable to access the repositories passed through the --enablerepo option.", + diagnosis="Unable to access repositories passed through the --enablerepo option.", remediations="For more details, see YUM/DNF output:\n{0}".format(output), ) return diff --git a/convert2rhel/actions/pre_ponr_changes/handle_packages.py b/convert2rhel/actions/pre_ponr_changes/handle_packages.py index 6c246c4adf..be3b0a0a2b 100644 --- a/convert2rhel/actions/pre_ponr_changes/handle_packages.py +++ b/convert2rhel/actions/pre_ponr_changes/handle_packages.py @@ -100,17 +100,18 @@ def run(self): all_pkgs = [] pkgs_removed = [] try: - logger.task("Searching for the following excluded packages") + logger.task("Remove special packages") + logger.info("Searching for the following excluded packages.") excluded_pkgs = sorted(pkghandler.get_packages_to_remove(system_info.excluded_pkgs)) - logger.task("Searching for packages containing .repo files or affecting variables in the .repo files") + logger.info("Searching for packages containing .repo files or affecting variables in the .repo files.") repofile_pkgs = sorted(pkghandler.get_packages_to_remove(system_info.repofile_pkgs)) logger.info("\n") all_pkgs = excluded_pkgs + repofile_pkgs if not all_pkgs: - logger.info("No packages to backup and remove.") + logger.info("No packages to back up and remove.") return # We're using the backed up yum repositories to prevent the following: @@ -146,8 +147,8 @@ def run(self): self.set_result( level="ERROR", id="SPECIAL_PACKAGE_REMOVAL_FAILED", - title="Failed to remove some packages necessary for the conversion.", - description="The cause of this error is unknown, please look at the diagnosis for more information.", + title="Failed to remove some packages necessary for the conversion", + description="The cause of this error is unknown. Look at the diagnosis for more information.", diagnosis=str(e), ) return @@ -161,7 +162,7 @@ def run(self): level="WARNING", id="SPECIAL_PACKAGES_NOT_REMOVED", title="Special packages not removed", - description="Special packages which could not be removed", + description="Certain packages could not be removed.", diagnosis=message, ) @@ -197,7 +198,7 @@ def _remove_packages_unless_from_redhat(pkgs_list, disable_repos=None): pkghandler.print_pkg_info(pkgs_list, disable_repos) pkgs_removed = utils.remove_pkgs(pkghandler.get_pkg_nevras(pkgs_list)) - logger.debug("Successfully removed {} packages".format(len(pkgs_list))) + logger.debug("Successfully removed {} packages.".format(len(pkgs_list))) return pkgs_removed diff --git a/convert2rhel/actions/pre_ponr_changes/kernel_modules.py b/convert2rhel/actions/pre_ponr_changes/kernel_modules.py index 06f5f2abd3..226341d01a 100644 --- a/convert2rhel/actions/pre_ponr_changes/kernel_modules.py +++ b/convert2rhel/actions/pre_ponr_changes/kernel_modules.py @@ -259,7 +259,7 @@ def run(self): self.add_message( level="WARNING", id="ALLOW_UNAVAILABLE_KERNEL_MODULES", - title="Did not perform the ensure kernel modules compatibility check", + title="Ignoring the check ensuring kernel module availability in RHEL", diagnosis="You have set the option to allow unavailable kernel modules.", description="We will continue the conversion with the following kernel modules unavailable in RHEL:\n" "{kmods}\n".format(kmods="\n".join(unsupported_kmods)), @@ -272,7 +272,7 @@ def run(self): level="OVERRIDABLE", id="UNSUPPORTED_KERNEL_MODULES", title="Unsupported kernel modules", - description="Unsupported kernel modules were found", + description="Unsupported kernel modules were found.", diagnosis="The following loaded kernel modules are not available in RHEL:\n{0}\n".format( "\n".join(unsupported_kmods) ), diff --git a/convert2rhel/actions/pre_ponr_changes/subscription.py b/convert2rhel/actions/pre_ponr_changes/subscription.py index 8646469209..8d9ce3a3e6 100644 --- a/convert2rhel/actions/pre_ponr_changes/subscription.py +++ b/convert2rhel/actions/pre_ponr_changes/subscription.py @@ -100,7 +100,7 @@ def run(self): logger.task("Subscription Manager - Check for installed packages") subscription_manager_pkgs = subscription.needed_subscription_manager_pkgs() if not subscription_manager_pkgs: - logger.info("Subscription Manager is already present") + logger.info("Subscription Manager is already present.") else: logger.task("Subscription Manager - Install packages") subscription.install_rhel_subscription_manager(subscription_manager_pkgs) @@ -118,7 +118,7 @@ def run(self): level="ERROR", id="UNKNOWN_ERROR", title="Unknown error", - description="The cause of this error is unknown, please look at the diagnosis for more information.", + description="The cause of this error is unknown. Look at the diagnosis for more information.", diagnosis=str(e), ) except exceptions.CriticalError as e: @@ -177,7 +177,7 @@ def run(self): level="ERROR", id="SYSTEM_NOT_REGISTERED", title="Not registered with RHSM", - description="This system must be registered with rhsm in order to get access to the RHEL rpms. In this case, the system was not already registered and no credentials were given to convert2rhel to register it.", + description="This system must be registered with RHSM in order to get access to RHEL rpms. In this case, the system has not been registered and no credentials were given to convert2rhel to register it.", remediations="You may either register this system via subscription-manager before running convert2rhel or give convert2rhel credentials to do that for you. The credentials convert2rhel would need are either activation_key and organization or username and password. You can set these in a config file and then pass the file to convert2rhel with the --config-file option.", ) return @@ -226,7 +226,7 @@ def run(self): level="ERROR", id="MISSING_SUBSCRIPTION_MANAGER_BINARY", title="Missing subscription-manager binary", - description="There is a missing subscription-manager binary", + description="There is a missing subscription-manager binary.", diagnosis="Failed to execute command: {}".format(e), ) except exceptions.CriticalError as e: @@ -246,7 +246,7 @@ def run(self): level="ERROR", id="UNKNOWN_ERROR", title="Unknown error", - description="The cause of this error is unknown, please look at the diagnosis for more information.", + description="The cause of this error is unknown. Look at the diagnosis for more information.", diagnosis=str(e), ) except ValueError as e: @@ -254,7 +254,7 @@ def run(self): level="ERROR", id="MISSING_REGISTRATION_COMBINATION", title="Missing registration combination", - description="There are missing registration combinations", + description="There are missing registration combinations.", diagnosis="One or more combinations were missing for subscription-manager parameters: {}".format( str(e) ), diff --git a/convert2rhel/actions/pre_ponr_changes/transaction.py b/convert2rhel/actions/pre_ponr_changes/transaction.py index 7e68f18ada..023c1efc58 100644 --- a/convert2rhel/actions/pre_ponr_changes/transaction.py +++ b/convert2rhel/actions/pre_ponr_changes/transaction.py @@ -42,7 +42,7 @@ def run(self): super(ValidatePackageManagerTransaction, self).run() try: - logger.task("Validate the %s transaction", pkgmanager.TYPE) + logger.task("Validate the main %s transaction", pkgmanager.TYPE) transaction_handler = pkgmanager.create_transaction_handler() transaction_handler.run_transaction( validate_transaction=True, diff --git a/convert2rhel/actions/system_checks/check_firewalld_availability.py b/convert2rhel/actions/system_checks/check_firewalld_availability.py index 34dc7b44bd..e0ec86244f 100644 --- a/convert2rhel/actions/system_checks/check_firewalld_availability.py +++ b/convert2rhel/actions/system_checks/check_firewalld_availability.py @@ -71,12 +71,12 @@ def _is_modules_cleanup_enabled(): # If the config file has this option set to true/yes, then we need to # return True to ask the user to change it to False. if list(filter(CLEANUP_MODULES_ON_EXIT_REGEX.match, contents)): - logger.debug("CleanupModulesOnExit option enabled in {}".format(FIREWALLD_CONFIG_FILE)) + logger.debug("CleanupModulesOnExit option is enabled in {}.".format(FIREWALLD_CONFIG_FILE)) return True # Default to return False as it is possible that the CleanupModulesOnExit # is set to no in the config already. - logger.debug("CleanupModulesOnExit option is disabled in {}".format(FIREWALLD_CONFIG_FILE)) + logger.debug("CleanupModulesOnExit option is disabled in {}.".format(FIREWALLD_CONFIG_FILE)) return False @@ -102,7 +102,7 @@ def run(self): self.set_result( level="ERROR", id="FIREWALLD_MODULES_CLEANUP_ON_EXIT_CONFIG", - title="Firewalld is set to cleanup modules after exit.", + title="Firewalld is set to cleanup modules after exit", description="Firewalld running on Oracle Linux 8 can lead to a conversion failure.", diagnosis=( "We've detected that firewalld unit is running and that causes iptables and nftables " diff --git a/convert2rhel/actions/system_checks/convert2rhel_latest.py b/convert2rhel/actions/system_checks/convert2rhel_latest.py index 375cf048c7..f79f4da607 100644 --- a/convert2rhel/actions/system_checks/convert2rhel_latest.py +++ b/convert2rhel/actions/system_checks/convert2rhel_latest.py @@ -44,7 +44,7 @@ class Convert2rhelLatest(actions.Action): def run(self): """Make sure that we are running the latest downstream version of convert2rhel""" - logger.task("Check if this is the latest version of Convert2RHEL") + logger.task("Check if this is the latest version of convert2rhel") super(Convert2rhelLatest, self).run() @@ -74,7 +74,7 @@ def run(self): level="WARNING", id="CONVERT2RHEL_LATEST_CHECK_SKIP", title="convert2rhel latest version check skip", - description="Did not perform the convert2hel latest version check", + description="Did not perform the convert2hel latest version check.", diagnosis=diagnosis, ) return @@ -94,7 +94,7 @@ def run(self): continue convert2rhel_versions.append(parsed_pkg) - logger.debug("Found {} convert2rhel package(s)".format(len(convert2rhel_versions))) + logger.debug("Found {} convert2rhel package(s).".format(len(convert2rhel_versions))) # This loop will determine the latest available convert2rhel version in the yum repo. # It assigns the epoch, version, and release ex: ("0", "0.26", "1.el7") to the latest_available_version variable. @@ -112,7 +112,7 @@ def run(self): ) latest_available_version = (package_version[1], package_version[2], package_version[3]) - logger.debug("Found {} to be latest available version".format(latest_available_version[1])) + logger.debug("Found {} to be latest available version.".format(latest_available_version[1])) precise_available_version = ("0", latest_available_version[1], "0") precise_convert2rhel_version = ("0", running_convert2rhel_version, "0") # Get source files that we're running with import convert2rhel ; convert2rhel.__file__ @@ -188,7 +188,7 @@ def run(self): level="WARNING", id="ALLOW_OLDER_VERSION_OPTION", title="Outdated convert2rhel version detected", - description="An outdated convert2rhel version has been detected", + description="An outdated convert2rhel version has been detected.", diagnosis=diagnosis, ) else: @@ -196,7 +196,7 @@ def run(self): level="OVERRIDABLE", id="OUT_OF_DATE", title="Outdated convert2rhel version detected", - description="An outdated convert2rhel version has been detected", + description="An outdated convert2rhel version has been detected.", diagnosis=( "You are currently running {} and the latest version of convert2rhel is {}.\n" "Only the latest version is supported for conversion.".format( diff --git a/convert2rhel/actions/system_checks/dbus.py b/convert2rhel/actions/system_checks/dbus.py index ac23576ca8..0da1e65e37 100644 --- a/convert2rhel/actions/system_checks/dbus.py +++ b/convert2rhel/actions/system_checks/dbus.py @@ -30,21 +30,21 @@ class DbusIsRunning(actions.Action): def run(self): """Error out if we need to register with rhsm and the dbus daemon is not running.""" super(DbusIsRunning, self).run() - logger.task("Check that DBus Daemon is running") + logger.task("Check that DBus daemon is running") if not subscription.should_subscribe(): logger.info("Did not perform the check because we have been asked not to subscribe this system to RHSM.") return if system_info.dbus_running: - logger.info("DBus Daemon is running") + logger.info("DBus daemon is running.") return self.set_result( level="ERROR", id="DBUS_DAEMON_NOT_RUNNING", title="Dbus daemon not running", - description="The Dbus daemon is not running", + description="The Dbus daemon is not running.", diagnosis="Could not find a running DBus Daemon which is needed to register with subscription manager.", - remediations="Please start dbus using `systemctl start dbus`", + remediations="Start dbus using `systemctl start dbus`", ) diff --git a/convert2rhel/actions/system_checks/duplicate_packages.py b/convert2rhel/actions/system_checks/duplicate_packages.py index 2d1ad50843..39e25157f1 100644 --- a/convert2rhel/actions/system_checks/duplicate_packages.py +++ b/convert2rhel/actions/system_checks/duplicate_packages.py @@ -31,7 +31,7 @@ def run(self): """Ensure that there are no duplicate system packages installed.""" super(DuplicatePackages, self).run() - logger.task("Check if there are any duplicate installed packages on the system") + logger.task("Check if there are any duplicate packages installed on the system") output, ret_code = utils.run_subprocess(["/usr/bin/package-cleanup", "--dupes", "--quiet"], print_output=False) if not output: return diff --git a/convert2rhel/actions/system_checks/efi.py b/convert2rhel/actions/system_checks/efi.py index 39293d0dc6..5df544fffa 100644 --- a/convert2rhel/actions/system_checks/efi.py +++ b/convert2rhel/actions/system_checks/efi.py @@ -78,7 +78,7 @@ def run(self): level="ERROR", id="BOOTLOADER_ERROR", title="Bootloader error detected", - description="An unknown bootloader error occurred, please look at the diagnosis for more information.", + description="An unknown bootloader error occurred. Look at the diagnosis for more information.", diagnosis=str(e), ) return diff --git a/convert2rhel/actions/system_checks/els.py b/convert2rhel/actions/system_checks/els.py index fcd45d2bdb..dbcec66169 100644 --- a/convert2rhel/actions/system_checks/els.py +++ b/convert2rhel/actions/system_checks/els.py @@ -30,9 +30,10 @@ class ElsSystemCheck(actions.Action): id = "ELS_SYSTEM_CHECK" def run(self): - """Warn the user if their system is under ELS and past the ELS release date without using the --els cli option.""" + """Warn users if their system is under ELS and past the ELS release date without using the --els cli option.""" super(ElsSystemCheck, self).run() + logger.task("Warn about not using --els on a system in the ELS phase") if system_info.version.major == 7: current_datetime = datetime.date.today() # Turn ELS_RELEASE_DATE into a datetime object @@ -44,7 +45,10 @@ def run(self): level="WARNING", id="ELS_COMMAND_LINE_OPTION_UNUSED", title="The --els command line option is unused", - description="Current system version is under Extended Lifecycle Support (ELS). You may want to consider using the --els" - " command line option to land on a system patched with the latest security errata.", + description="Current system version is under Extended Lifecycle Support (ELS). You may want to" + " consider using the --els command line option to land on a system patched with the latest security" + " errata.", ) + else: + logger.info("Applicable only to conversions to RHEL 7.") return diff --git a/convert2rhel/actions/system_checks/eus.py b/convert2rhel/actions/system_checks/eus.py index e40e6635ff..e0bb2b56ad 100644 --- a/convert2rhel/actions/system_checks/eus.py +++ b/convert2rhel/actions/system_checks/eus.py @@ -30,9 +30,10 @@ class EusSystemCheck(actions.Action): id = "EUS_SYSTEM_CHECK" def run(self): - """Warn the user if their system is under EUS and past the EUS release date without using the --eus cli option.""" + """Warn users if their system is under EUS and past the EUS release date without using the --eus cli option.""" super(EusSystemCheck, self).run() + logger.task("Warn about not using --eus on a system in the EUS phase") current_version = "{}.{}".format(system_info.version.major, system_info.version.minor) eus_versions = list(EUS_MINOR_VERSIONS.keys()) if current_version in eus_versions: @@ -47,7 +48,22 @@ def run(self): level="WARNING", id="EUS_COMMAND_LINE_OPTION_UNUSED", title="The --eus command line option is unused", - description="Current system version is under Extended Update Support (EUS). You may want to consider using the --eus" - " command line option to land on a system patched with the latest security errata.", + description="Current system version is under Extended Update Support (EUS). You may want to" + " consider using the --eus command line option to land on a system patched with the latest security" + " errata.", ) + else: + logger.info( + "Applicable only when converting the following system versions:\n{}".format( + "\n".join( + [ + "{} after {}".format( + system_info.name, + version, + ) + for version in EUS_MINOR_VERSIONS + ] + ) + ) + ) return diff --git a/convert2rhel/actions/system_checks/grub_validity.py b/convert2rhel/actions/system_checks/grub_validity.py index e8b5304d25..710f6d12d8 100644 --- a/convert2rhel/actions/system_checks/grub_validity.py +++ b/convert2rhel/actions/system_checks/grub_validity.py @@ -31,17 +31,18 @@ def run(self): is invalid. """ super(GrubValidity, self).run() - logger.task("Check if the grub file is valid") + logger.task("Check validity of /etc/default/grub") output, ret_code = utils.run_subprocess(["grub2-mkconfig"], print_output=False) if ret_code != 0: self.set_result( level="ERROR", id="INVALID_GRUB_FILE", - title="Grub boot entry file is invalid", - description="The grub file seems to be invalid leaving the system in a" - " non-clean state and must be fixed before continuing the conversion" - " to ensure a smooth process.", - remediations="Check the grub file inside `/etc/default` directory and remove any " - "misconfigurations, then re-run the conversion.", + title="/etc/default/grub invalid", + description="The /etc/default/grub file seems to be invalid and must be fixed before continuing the" + "conversion.", + diagnosis="Calling grub2-mkconfig failed with:\n{}".format(output), + remediations="Fix issues reported by the grub2-mkconfig utility and re-run the conversion.", ) + else: + logger.info("No issues found with the /etc/default/grub file.") diff --git a/convert2rhel/actions/system_checks/is_loaded_kernel_latest.py b/convert2rhel/actions/system_checks/is_loaded_kernel_latest.py index 02e023b132..92a909e292 100644 --- a/convert2rhel/actions/system_checks/is_loaded_kernel_latest.py +++ b/convert2rhel/actions/system_checks/is_loaded_kernel_latest.py @@ -96,7 +96,7 @@ def run(self): logger.debug("Got the following output: %s", repoquery_output) logger.warning( "Couldn't fetch the list of the most recent kernels available in " - "the repositories. Did not perform the loaded kernel check." + "the repositories. Did not perform the loaded kernel currency check." ) self.add_message( level="WARNING", @@ -104,7 +104,7 @@ def run(self): title="Unable to fetch recent kernels", description=( "Couldn't fetch the list of the most recent kernels available in " - "the repositories. Did not perform the loaded kernel check." + "the repositories. Did not perform the loaded kernel currency check." ), ) return @@ -132,14 +132,14 @@ def run(self): level="OVERRIDABLE", id="KERNEL_CURRENCY_CHECK_FAIL", title="Kernel currency check failed", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=( "Could not find any {} from repositories to compare against the loaded kernel.".format( package_to_check ) ), remediations=( - "Please check if you have any vendor repositories enabled to proceed with the conversion.\n" + "Check if you have any vendor repositories enabled to proceed with the conversion.\n" "If you wish to disregard this message, set the skip_kernel_currency_check inhibitor override in" " the /etc/convert2rhel.ini config file to true." ), @@ -162,7 +162,7 @@ def run(self): level="WARNING", id="INVALID_KERNEL_PACKAGE", title="Invalid kernel package found", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=str(exc), ) return @@ -172,7 +172,7 @@ def run(self): level="OVERRIDABLE", id="INVALID_KERNEL_VERSION", title="Invalid kernel version detected", - description="The loaded kernel version mismatch the latest one available in system repositories", + description="The loaded kernel version mismatch the latest one available in system repositories.", diagnosis=( "The version of the loaded kernel is different from the latest version in system repositories. \n" " Latest kernel version available in {}: {}\n" diff --git a/convert2rhel/actions/system_checks/package_updates.py b/convert2rhel/actions/system_checks/package_updates.py index 0572fcba9f..d88ec3a795 100644 --- a/convert2rhel/actions/system_checks/package_updates.py +++ b/convert2rhel/actions/system_checks/package_updates.py @@ -42,7 +42,7 @@ def run(self): level="INFO", id="PACKAGE_UPDATES_CHECK_SKIP_NO_PUBLIC_REPOSITORIES", title="Did not perform the package updates check", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=( "Did not perform the check because there were no publicly available %s %d.%d repositories available." % (system_info.name, system_info.version.major, system_info.version.minor) @@ -71,7 +71,7 @@ def run(self): level="WARNING", id="PACKAGE_UP_TO_DATE_CHECK_MESSAGE", title="Package up to date check fail", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=package_up_to_date_error_message, ) return @@ -79,7 +79,7 @@ def run(self): if len(packages_to_update) > 0: package_not_up_to_date_error_message = ( "The system has {} package(s) not updated based on repositories defined in the system repositories.\n" - "List of packages to update: {}.\n\n" + "List of packages to update: {}\n\n" "Not updating the packages may cause the conversion to fail.\n" "Consider updating the packages before proceeding with the conversion.".format( len(packages_to_update), " ".join(packages_to_update) @@ -90,7 +90,7 @@ def run(self): level="WARNING", id="OUT_OF_DATE_PACKAGES", title="Outdated packages detected", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=package_not_up_to_date_error_message, remediations="Run yum update to update all the packages on the system.", ) diff --git a/convert2rhel/actions/system_checks/rhel_compatible_kernel.py b/convert2rhel/actions/system_checks/rhel_compatible_kernel.py index 9945597a7a..c1db14efeb 100644 --- a/convert2rhel/actions/system_checks/rhel_compatible_kernel.py +++ b/convert2rhel/actions/system_checks/rhel_compatible_kernel.py @@ -70,7 +70,7 @@ def run(self): level="ERROR", id=e.error_id, title="Incompatible booted kernel version", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=( "The booted kernel version is incompatible with the standard RHEL kernel. {}".format( bad_kernel_message diff --git a/convert2rhel/actions/system_checks/tainted_kmods.py b/convert2rhel/actions/system_checks/tainted_kmods.py index 5f56293f58..8d7adc3592 100644 --- a/convert2rhel/actions/system_checks/tainted_kmods.py +++ b/convert2rhel/actions/system_checks/tainted_kmods.py @@ -57,7 +57,7 @@ def run(self): level="OVERRIDABLE", id="TAINTED_KMODS_DETECTED", title="Tainted kernel modules detected", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=diagnosis, remediations=( "Prevent the modules from loading by following {0}" @@ -66,7 +66,7 @@ def run(self): " tainted_kernel_module_check_skip inhibitor override in the /etc/convert2rhel.ini" " config file to true. Overriding this check can be dangerous" " so it is recommended that you do a system backup beforehand." - " For information on what a tainted kernel module is, please refer to this documentation {1}".format( + " For information on what a tainted kernel module is, refer to this documentation {1}".format( LINK_PREVENT_KMODS_FROM_LOADING, LINK_TAINTED_KMOD_DOCS ) ), @@ -87,12 +87,12 @@ def run(self): level="WARNING", id="TAINTED_KMODS_DETECTED_MESSAGE", title="Tainted kernel modules detected", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=diagnosis, remediations=( "Prevent the modules from loading by following {0}" " and run convert2rhel again to continue with the conversion." - " For information on what a tainted kernel module is, please refer to this documentation {1}".format( + " For information on what a tainted kernel module is, refer to this documentation {1}".format( LINK_PREVENT_KMODS_FROM_LOADING, LINK_TAINTED_KMOD_DOCS ) ), diff --git a/convert2rhel/backup/__init__.py b/convert2rhel/backup/__init__.py index 47776c38aa..ee064628b4 100644 --- a/convert2rhel/backup/__init__.py +++ b/convert2rhel/backup/__init__.py @@ -74,7 +74,7 @@ def push(self, restorable): # if it is, we skip it for r in self._restorables: if r == restorable: - logger.debug("Skipping: {} has already been backed up".format(restorable.__class__.__name__)) + logger.debug("Skipping: {} has already been backed up.".format(restorable.__class__.__name__)) return restorable.enable() diff --git a/convert2rhel/backup/certs.py b/convert2rhel/backup/certs.py index 92b9f409a2..6611a99e76 100644 --- a/convert2rhel/backup/certs.py +++ b/convert2rhel/backup/certs.py @@ -122,7 +122,7 @@ def enable(self): logger.critical_no_exit("OSError({0}): {1}".format(err.errno, err.strerror)) raise exceptions.CriticalError( id_="FAILED_TO_INSTALL_CERTIFICATE", - title="Failed to install certificate.", + title="Failed to install a certificate", description="convert2rhel was unable to install a required certificate. This certificate allows the pre-conversion analysis to verify that packages are legitimate RHEL packages.", diagnosis="Failed to install certificate {} to {}. Errno: {}, Error: {}".format( self._get_source_cert_path, self._target_cert_dir, err.errno, err.strerror @@ -171,7 +171,7 @@ def _restore(self): if "not owned by any package" in output: file_unowned = True elif "No such file or directory" in output: - logger.info("Certificate already removed from {}".format(self._target_cert_path)) + logger.info("Certificate already removed from {}.".format(self._target_cert_path)) else: logger.warning( "Unable to determine if a package owns certificate {}. Skipping removal.".format( @@ -190,7 +190,7 @@ def _restore(self): try: os.remove(self._target_cert_path) - logger.info("Certificate {} removed".format(self._target_cert_path)) + logger.info("Certificate {} removed.".format(self._target_cert_path)) except OSError as err: if err.errno == errno.ENOENT: # Resolves RHSM error when removing certs, as the system might not have installed any certs yet diff --git a/convert2rhel/backup/files.py b/convert2rhel/backup/files.py index 2622817aa8..f40274a740 100644 --- a/convert2rhel/backup/files.py +++ b/convert2rhel/backup/files.py @@ -65,7 +65,7 @@ def enable(self): logger.critical_no_exit("Error({}): {}".format(err.errno, err.strerror)) raise exceptions.CriticalError( id_="FAILED_TO_SAVE_FILE_TO_BACKUP_DIR", - title="Failed to copy file to the backup directory.", + title="Failed to copy file to the backup directory", description=( "Copying the current file has failed. This can lead to inconsistency during the rollbacks as " "convert2rhel won't be able to restore the file in case of failures." @@ -124,7 +124,7 @@ def restore(self, rollback=True): if rollback: logger.task("Restore {} from backup".format(self.filepath)) else: - logger.info("Restoring {} from backup".format(self.filepath)) + logger.info("Restoring {} from backup.".format(self.filepath)) if not self.enabled: logger.info("{} hasn't been backed up.".format(self.filepath)) @@ -201,10 +201,10 @@ def restore(self): logger.task("Remove file created during conversion {filepath}".format(filepath=self.filepath)) if not os.path.isfile(self.filepath): - logger.info("File {filepath} wasn't created during conversion".format(filepath=self.filepath)) + logger.info("File {filepath} wasn't created during conversion.".format(filepath=self.filepath)) else: # Possible exceptions will be handled in the BackupController os.remove(self.filepath) - logger.info("File {filepath} removed".format(filepath=self.filepath)) + logger.info("File {filepath} removed.".format(filepath=self.filepath)) super(MissingFile, self).restore() diff --git a/convert2rhel/backup/packages.py b/convert2rhel/backup/packages.py index 2ab1a44275..0ce4e41437 100644 --- a/convert2rhel/backup/packages.py +++ b/convert2rhel/backup/packages.py @@ -86,7 +86,7 @@ def enable(self): return if not os.path.isdir(BACKUP_DIR): - logger.warning("Can't access {}".format(BACKUP_DIR)) + logger.warning("Can't access {}.".format(BACKUP_DIR)) return logger.info("Backing up the packages: {}.".format(",".join(self.pkgs))) @@ -127,15 +127,17 @@ def restore(self): logger.task("Install removed packages") if not self._backedup_pkgs_paths: - logger.warning("Couldn't find a backup for {} package.".format(",".join(self.pkgs))) + logger.warning("Couldn't find a backup for the following package(s): {}".format(",".join(self.pkgs))) raise exceptions.CriticalError( id_="FAILED_TO_INSTALL_PACKAGES", - title="Couldn't find package backup", + title="Couldn't find a package backup", description=( "While attempting to roll back changes, we encountered " "an unexpected failure while we cannot find a package backup." ), - diagnosis="Couldn't find a backup for {} package.".format(utils.format_sequence_as_message(self.pkgs)), + diagnosis="Couldn't find a backup for the following package(s): {}".format( + utils.format_sequence_as_message(self.pkgs) + ), ) self._install_local_rpms(replace=True, critical=True) @@ -165,7 +167,7 @@ def _install_local_rpms(self, replace=False, critical=True): logger.critical_no_exit("Error: Couldn't install {} packages.".format(pkgs_as_str)) raise exceptions.CriticalError( id_="FAILED_TO_INSTALL_PACKAGES", - title="Couldn't install packages.", + title="Couldn't install packages", description=( "While attempting to roll back changes, we encountered " "an unexpected failure while attempting to reinstall " @@ -250,7 +252,7 @@ def _enable(self): exit early. """ if not self.pkgs_to_install: - logger.info("All packages were already installed") + logger.info("All packages were already installed.") return formatted_pkgs_sequence = utils.format_sequence_as_message(self.pkgs_to_install) @@ -277,7 +279,7 @@ def _enable(self): ) raise exceptions.CriticalError( id_="FAILED_TO_INSTALL_SCHEDULED_PACKAGES", - title="Failed to install scheduled packages.", + title="Failed to install scheduled packages", description="convert2rhel was unable to install scheduled packages.", diagnosis="Failed to install packages {}. Output: {}, Status: {}".format( formatted_pkgs_sequence, output, ret_code @@ -301,7 +303,7 @@ def restore(self): return logger.task("Remove installed packages") - logger.info("Removing set of installed pkgs: {}".format(utils.format_sequence_as_message(self.installed_pkgs))) + logger.info("Removing installed packages: {}".format(utils.format_sequence_as_message(self.installed_pkgs))) utils.remove_pkgs(self.installed_pkgs, critical=False) super(RestorablePackageSet, self).restore() diff --git a/convert2rhel/backup/subscription.py b/convert2rhel/backup/subscription.py index ed61e28971..f08ea33a82 100644 --- a/convert2rhel/backup/subscription.py +++ b/convert2rhel/backup/subscription.py @@ -59,7 +59,7 @@ def restore(self): except subscription.UnregisterError as e: logger.warning(str(e)) except OSError: - logger.warning("subscription-manager not installed, skipping") + logger.warning("subscription-manager not installed, skipping.") super(RestorableSystemSubscription, self).restore() @@ -82,7 +82,7 @@ def enable(self): def restore(self): if self._is_attached: - logger.task("Removing auto-attached subscription") + logger.task("Remove auto-attached subscription") subscription.remove_subscription() super(RestorableAutoAttachmentSubscription, self).restore() @@ -135,7 +135,7 @@ def restore(self): if not self.enabled: return - logger.task("Restoring state of the repositories") + logger.task("Restore state of the repositories") if self._repos_to_enable: logger.debug("Repositories to enable: {}".format(",".join(self._repos_to_enable))) diff --git a/convert2rhel/main.py b/convert2rhel/main.py index 704149be1f..9191ba17bd 100644 --- a/convert2rhel/main.py +++ b/convert2rhel/main.py @@ -88,7 +88,7 @@ def initialize_file_logging(log_name, log_dir): try: logger_module.archive_old_logger_files(log_name, log_dir) except (IOError, OSError) as e: - loggerinst.warning("Unable to archive previous log: {}".format(e)) + loggerinst.warning("Unable to archive the previous log file: {}".format(e)) logger_module.add_file_handler(log_name, log_dir) @@ -405,7 +405,7 @@ def rollback_changes(): backup.backup_control.pop_all() except IndexError as e: if e.args[0] == "No backups to restore": - loggerinst.info("During rollback there were no backups to restore") + loggerinst.info("During rollback there were no backups to restore.") else: raise diff --git a/convert2rhel/pkghandler.py b/convert2rhel/pkghandler.py index 98f2a2d51c..27c14f47c8 100644 --- a/convert2rhel/pkghandler.py +++ b/convert2rhel/pkghandler.py @@ -658,7 +658,7 @@ def replace_non_rhel_installed_kernel(version): if not path: logger.critical("Unable to download the RHEL kernel package.") - logger.info("Replacing {} {} with RHEL kernel with the same NEVRA ... ".format(system_info.name, pkg)) + logger.info("Replacing {} {} with RHEL kernel with the same NEVRA.".format(system_info.name, pkg)) output, ret_code = utils.run_subprocess( # The --nodeps is needed as some kernels depend on system-release (alias for redhat-release) and that package # is not installed at this stage. @@ -683,7 +683,6 @@ def update_rhel_kernel(): convert2rhel needs to install older RHEL kernel version first. In this function, RHEL kernel is updated to the latest available version. """ - logger.info("Updating RHEL kernel.") pkgmanager.call_yum_cmd(command="update", args=["kernel"]) @@ -703,7 +702,7 @@ def clear_versionlock(): backup.backup_control.push(RestorableFile(VERSIONLOCK_FILE_PATH)) - logger.info("Clearing package versions locks...") + logger.info("Clearing package versions locks.") pkgmanager.call_yum_cmd("versionlock", args=["clear"], print_output=False) else: logger.info("Usage of YUM/DNF versionlock plugin not detected.") diff --git a/convert2rhel/pkgmanager/handlers/dnf/__init__.py b/convert2rhel/pkgmanager/handlers/dnf/__init__.py index 1651f3aa3a..a5fb315133 100644 --- a/convert2rhel/pkgmanager/handlers/dnf/__init__.py +++ b/convert2rhel/pkgmanager/handlers/dnf/__init__.py @@ -111,7 +111,7 @@ def _enable_repos(self): logger.critical_no_exit("Failed to populate repository metadata.") raise exceptions.CriticalError( id_="FAILED_TO_ENABLE_REPOS", - title="Failed to enable repositories.", + title="Failed to enable repositories", description="We've encountered a failure when accessing repository metadata.", diagnosis="Loading repository metadata failed with error {}.".format(str(e)), ) @@ -183,7 +183,7 @@ def _resolve_dependencies(self): :raises SystemExit: If we fail to resolve the dependencies or downloading the packages. """ - logger.info("Resolving the dependencies of the packages in the dnf transaction set.") + logger.info("Resolving dependencies of the packages in the dnf transaction set.") try: self._base.resolve(allow_erasing=True) except pkgmanager.exceptions.DepsolveError as e: @@ -191,7 +191,7 @@ def _resolve_dependencies(self): logger.critical_no_exit("Failed to resolve dependencies in the transaction.") raise exceptions.CriticalError( id_="FAILED_TO_RESOLVE_DEPENDENCIES", - title="Failed to resolve dependencies.", + title="Failed to resolve dependencies", description="During package transaction dnf failed to resolve the necessary dependencies needed for a package replacement.", diagnosis="Resolve dependencies failed with error {}.".format(str(e)), ) @@ -204,7 +204,7 @@ def _resolve_dependencies(self): logger.critical_no_exit("Failed to download the transaction packages.") raise exceptions.CriticalError( id_="FAILED_TO_DOWNLOAD_TRANSACTION_PACKAGES", - title="Failed to download packages in the transaction.", + title="Failed to download packages in the transaction", description="During package transaction dnf failed to download the necessary packages needed for the transaction.", diagnosis="Package download failed with error {}.".format(str(e)), ) @@ -231,11 +231,11 @@ def _process_transaction(self, validate_transaction): pkgmanager.exceptions.TransactionCheckError, ) as e: logger.debug("Got the following exception message: %s", e) - logger.critical_no_exit("Failed to validate the dnf transaction.") + logger.critical_no_exit("Failed to validate a dnf transaction.") raise exceptions.CriticalError( id_="FAILED_TO_VALIDATE_TRANSACTION", - title="Failed to validate dnf transaction.", - description="During the dnf transaction execution an error occured and convert2rhel could no longer process the transaction.", + title="Failed to validate a dnf transaction", + description="During the dnf transaction execution an error occurred and convert2rhel could no longer process the transaction.", diagnosis="Transaction processing failed with error: {}".format(str(e)), ) diff --git a/convert2rhel/pkgmanager/handlers/yum/__init__.py b/convert2rhel/pkgmanager/handlers/yum/__init__.py index 5449e7c139..92907c1412 100644 --- a/convert2rhel/pkgmanager/handlers/yum/__init__.py +++ b/convert2rhel/pkgmanager/handlers/yum/__init__.py @@ -168,7 +168,7 @@ def _enable_repos(self): logger.critical_no_exit("Failed to populate repository metadata.") raise exceptions.CriticalError( id_="FAILED_TO_ENABLE_REPOS", - title="Failed to enable repositories.", + title="Failed to enable repositories", description="We've encountered a failure when accessing repository metadata.", diagnosis="Loading repository metadata failed with error {}.".format(str(e)), ) @@ -236,7 +236,7 @@ def _perform_operations(self): logger.critical_no_exit("There are no suitable mirrors available for the loaded repositories.") raise exceptions.CriticalError( id_="FAILED_TO_LOAD_REPOSITORIES", - title="Failed to find suitable mirrors for the load repositories.", + title="Failed to find suitable mirrors for the load repositories", description="All available mirrors were tried and none were available.", diagnosis="Repository mirrors failed with error {}.".format(str(e)), ) @@ -270,7 +270,7 @@ def _resolve_dependencies(self): return that message, otherwise, return None. :rtype: str | None """ - logger.info("Resolving the dependencies of the packages in the yum transaction set.") + logger.info("Resolving dependencies of the packages in the yum transaction set.") ret_code, msg = self._base.resolveDeps() if ret_code == 1: @@ -318,10 +318,10 @@ def _process_transaction(self, validate_transaction): # - pkgmanager.Errors.YumBaseError # - pkgmanager.Errors.YumGPGCheckError logger.debug("Got the following exception message: %s", e) - logger.critical_no_exit("Failed to validate the yum transaction.") + logger.critical_no_exit("Failed to validate a yum transaction.") raise exceptions.CriticalError( id_="FAILED_TO_VALIDATE_TRANSACTION", - title="Failed to validate yum transaction.", + title="Failed to validate a yum transaction", description="During the yum transaction execution an error occurred and convert2rhel could no longer process the transaction.", diagnosis="Transaction processing failed with error: {}".format(" ".join(e.value)), ) @@ -354,7 +354,7 @@ def run_transaction(self, validate_transaction=False): if "Depsolving loop limit reached" not in messages and validate_transaction: _resolve_yum_problematic_dependencies(messages) - logger.info("Retrying to resolve dependencies %s", attempts) + logger.info("Retrying to resolve dependencies - attempt %s.", attempts) attempts += 1 else: resolve_deps_finished = True @@ -364,7 +364,7 @@ def run_transaction(self, validate_transaction=False): logger.critical_no_exit("Failed to resolve dependencies in the transaction.") raise exceptions.CriticalError( id_="FAILED_TO_RESOLVE_DEPENDENCIES", - title="Failed to resolve dependencies.", + title="Failed to resolve dependencies", description="During package transaction yum failed to resolve the necessary dependencies needed for a package replacement.", ) finally: diff --git a/convert2rhel/redhatrelease.py b/convert2rhel/redhatrelease.py index 108be40fb0..b414042ba8 100644 --- a/convert2rhel/redhatrelease.py +++ b/convert2rhel/redhatrelease.py @@ -36,7 +36,7 @@ def get_system_release_filepath(): release_filepath = "/etc/system-release" # RHEL 7/8 based OSes if os.path.isfile(release_filepath): return release_filepath - logger.critical("Error: Unable to find the /etc/system-release file containing the OS name and version") + logger.critical("Error: Unable to find the /etc/system-release file containing the OS name and version.") def get_system_release_content(): diff --git a/convert2rhel/repo.py b/convert2rhel/repo.py index ddfa5690c7..3109269dac 100644 --- a/convert2rhel/repo.py +++ b/convert2rhel/repo.py @@ -239,5 +239,5 @@ def write_temporary_repofile(contents): raise exceptions.CriticalError( id_="STORE_REPOFILE_FAILED", title="Failed to store a repository file", - description="Failed to write a repository file contents to {}.\n" "Reason: {}".format(f.name, str(err)), + description="Failed to write a repository file contents to {}.\nReason: {}".format(f.name, str(err)), ) diff --git a/convert2rhel/subscription.py b/convert2rhel/subscription.py index 9b4cc736bb..77e931c859 100644 --- a/convert2rhel/subscription.py +++ b/convert2rhel/subscription.py @@ -161,7 +161,7 @@ def register_system(): ) logger.info( - "%sRegistering the system using subscription-manager ...", + "%sRegistering the system using subscription-manager.", attempt_msg, ) @@ -217,7 +217,7 @@ def register_system(): ) raise exceptions.CriticalError( id_="FAILED_TO_SUBSCRIBE_SYSTEM", - title="Failed to subscribe system.", + title="Failed to restore /etc/os-release", description="Failed to restore the /etc/os-release file needed for subscribing the system.", diagnosis="The restore failed with error {}.".format(str(e)), ) @@ -247,8 +247,10 @@ def register_system(): logger.critical_no_exit("Unable to register the system through subscription-manager.") raise exceptions.CriticalError( id_="FAILED_TO_SUBSCRIBE_SYSTEM", - title="Failed to subscribe system.", - description="After several attempts, convert2rhel was unable to subscribe the system using subscription-manager. This issue might occur because of but not limited to DBus, file permission-related issues, bad credentials, or network issues.", + title="Failed to subscribe the system", + description="After several attempts, convert2rhel was unable to subscribe the system using" + " subscription-manager. This issue might occur because of but not limited to DBus," + " file permission-related issues, bad credentials, or network issues.", diagnosis="System registration failed with error {}.".format(str(troublesome_exception)), ) @@ -442,14 +444,14 @@ def __call__(self): # if we need one in the future. REGISTER_OPTS_DICT = dbus.Dictionary({}, signature="sv", variant_level=1) - logger.debug("Getting a handle to the system dbus") + logger.debug("Getting a handle to the system dbus.") system_bus = dbus.SystemBus() # Create a new bus so we can talk to rhsm privately (For security: # talking on the system bus might be eavesdropped in certain scenarios) - logger.debug("Getting a subscription-manager RegisterServer object from dbus") + logger.debug("Getting a subscription-manager RegisterServer object from dbus.") register_server = system_bus.get_object("com.redhat.RHSM1", "/com/redhat/RHSM1/RegisterServer") - logger.debug("Starting a private DBus to talk to subscription-manager") + logger.debug("Starting a private DBus to talk to subscription-manager.") address = register_server.Start( i18n.SUBSCRIPTION_MANAGER_LOCALE, dbus_interface="com.redhat.RHSM1.RegisterServer", @@ -457,7 +459,7 @@ def __call__(self): try: # Use the private bus to register the machine - logger.debug("Connecting to the private DBus") + logger.debug("Connecting to the private DBus.") private_bus = dbus.connection.Connection(address) try: @@ -529,7 +531,7 @@ def __call__(self): finally: # Always shut down the private bus - logger.debug("Shutting down private DBus instance") + logger.debug("Shutting down private DBus instance.") register_server.Stop( i18n.SUBSCRIPTION_MANAGER_LOCALE, dbus_interface="com.redhat.RHSM1.RegisterServer", @@ -675,7 +677,7 @@ def attach_subscription(): """ # check if SCA is enabled if is_sca_enabled(): - logger.info("Simple Content Access is enabled, skipping subscription attachment") + logger.info("Simple Content Access is enabled, skipping subscription attachment.") if tool_opts.pool: logger.warning( "Because Simple Content Access is enabled the subscription specified by the pool ID will not be attached." @@ -705,13 +707,13 @@ def attach_subscription(): # Unsuccessful attachment, e.g. the pool ID is incorrect or the # number of purchased attachments has been depleted. logger.critical_no_exit( - "Unsuccessful attachment of a subscription. Please refer to https://access.redhat.com/management/" + "Unsuccessful attachment of a subscription. Refer to https://access.redhat.com/management/" " where you can either enable the SCA, create an activation key, or find a Pool ID of the subscription" " you wish to use and pass it to convert2rhel through the `--pool` CLI option." ) raise exceptions.CriticalError( id_="FAILED_TO_ATTACH_SUBSCRIPTION", - title="Failed to attach a subscription to the system.", + title="Failed to attach a subscription to the system", description="convert2rhel was unable to attach a subscription to the system. An attached subscription is required for RHEL package installation.", remediations="Refer to https://access.redhat.com/management/ where you can enable Simple Content Access, create an activation key, or find a Pool ID of the subscription you wish to use and pass it to convert2rhel through the `--pool` CLI option.", ) @@ -735,7 +737,7 @@ def verify_rhsm_installed(): ) raise exceptions.CriticalError( id_="FAILED_TO_VERIFY_SUBSCRIPTION_MANAGER", - title="Failed to verify subscription-manager package.", + title="Failed to verify the subscription-manager package", description="The subscription-manager package is not installed correctly. Therefore, the pre-conversion analysis cannot verify that the correct package is installed on your system.", remediations="Manually installing subscription-manager before running convert2rhel.", ) @@ -756,7 +758,7 @@ def disable_repos(): logger.critical_no_exit("Could not disable subscription-manager repositories:\n{}".format(output)) raise exceptions.CriticalError( id_="FAILED_TO_DISABLE_SUBSCRIPTION_MANAGER_REPOSITORIES", - title="Could not disable repositories through subscription-manager.", + title="Could not disable repositories through subscription-manager", description="As part of the conversion process, convert2rhel disables all current subscription-manager repositories and enables only repositories required for the conversion. convert2rhel was unable to disable these repositories, and the conversion is unable to proceed.", diagnosis="Failed to disable repositories: {}.".format(output), ) @@ -806,7 +808,7 @@ def submgr_enable_repos(repos_to_enable): description=description, ) - logger.info("Repositories enabled through subscription-manager") + logger.info("Repositories enabled through subscription-manager.") def needed_subscription_manager_pkgs(): diff --git a/convert2rhel/systeminfo.py b/convert2rhel/systeminfo.py index e296c10d34..c35a72c0e0 100644 --- a/convert2rhel/systeminfo.py +++ b/convert2rhel/systeminfo.py @@ -455,7 +455,7 @@ def corresponds_to_rhel_eus_release(self): current_version = repr(self.version) if tool_opts.eus and current_version in EUS_MINOR_VERSIONS: - self.logger.info("EUS argument detected, automatically evaluating system as EUS") + self.logger.info("EUS argument detected, automatically evaluating system as EUS.") return True return False diff --git a/convert2rhel/toolopts/__init__.py b/convert2rhel/toolopts/__init__.py index 6094dd7610..e6add700f3 100644 --- a/convert2rhel/toolopts/__init__.py +++ b/convert2rhel/toolopts/__init__.py @@ -67,13 +67,13 @@ def _handle_config_conflict(self, config_sources): if (cli_config.password or file_config.password) and not (cli_config.username or file_config.username): loggerinst.warning( - "You have passed the RHSM password without an associated username. Please provide a username together" + "You have passed the RHSM password without an associated username. Provide a username together" " with the password." ) if (cli_config.username or file_config.username) and not (cli_config.password or file_config.password): loggerinst.warning( - "You have passed the RHSM username without an associated password. Please provide a password together" + "You have passed the RHSM username without an associated password. Provide a password together" " with the username." ) diff --git a/convert2rhel/toolopts/config.py b/convert2rhel/toolopts/config.py index 8c6cac6635..632ef008f1 100644 --- a/convert2rhel/toolopts/config.py +++ b/convert2rhel/toolopts/config.py @@ -196,7 +196,7 @@ def _get_options_value(self, config_file, header, supported_opts): for option in conf_options: if option.lower() not in supported_opts: - loggerinst.warning("Unsupported option '{}' in '{}'".format(option, header)) + loggerinst.warning("Unsupported option '{}' in '{}'.".format(option, header)) continue # This is the only header that can contain boolean values for now. @@ -292,13 +292,13 @@ def _validate(self, opts): if opts["username"] and not opts["password"]: loggerinst.warning( - "You have passed the RHSM username without an associated password. Please provide a password together" + "You have passed the RHSM username without an associated password. Provide a password together" " with the username." ) if opts["password"] and not opts["username"]: loggerinst.warning( - "You have passed the RHSM password without an associated username. Please provide a username together" + "You have passed the RHSM password without an associated username. Provide a username together" " with the password." ) diff --git a/convert2rhel/unit_tests/actions/conversion/preserve_only_rhel_kernel_test.py b/convert2rhel/unit_tests/actions/conversion/preserve_only_rhel_kernel_test.py index 8d6eb6392c..239948958c 100644 --- a/convert2rhel/unit_tests/actions/conversion/preserve_only_rhel_kernel_test.py +++ b/convert2rhel/unit_tests/actions/conversion/preserve_only_rhel_kernel_test.py @@ -238,8 +238,8 @@ def test_fix_invalid_grub2_entries(self, caplog, monkeypatch, fix_invalid_grub2_ actions.ActionMessage( level="WARNING", id="UNABLE_TO_GET_GRUB2_BOOT_LOADER_ENTRY", - title="Unable to get the GRUB2 boot loader entry", - description="Couldn't get the default GRUB2 boot loader entry:\nbootloader", + title="Unable to get the GRUB2 bootloader entry", + description="Couldn't get the default GRUB2 bootloader entry:\nbootloader", diagnosis=None, remediations=None, ), @@ -254,8 +254,8 @@ def test_fix_invalid_grub2_entries(self, caplog, monkeypatch, fix_invalid_grub2_ actions.ActionMessage( level="WARNING", id="UNABLE_TO_SET_GRUB2_BOOT_LOADER_ENTRY", - title="Unable to set the GRUB2 boot loader entry", - description="Couldn't set the default GRUB2 boot loader entry:\nbootloader", + title="Unable to set the GRUB2 bootloader entry", + description="Couldn't set the default GRUB2 bootloader entry:\nbootloader", diagnosis=None, remediations=None, ), @@ -364,9 +364,9 @@ def test_fix_invalid_grub2_entries_execution( ) fix_invalid_grub2_entries_instance.run() if expected: - assert "Fixing GRUB boot loader" in caplog.text + assert "Setting RHEL kernel" in caplog.text else: - assert "Fixing GRUB boot loader" not in caplog.text + assert "Setting RHEL kernel" not in caplog.text class TestFixDefaultKernel: @@ -421,7 +421,7 @@ def test_fix_default_kernel_converting_success( warning_msgs = [r for r in caplog.records if r.levelname == "WARNING"] assert warning_msgs - assert "Detected leftover boot kernel, changing to RHEL kernel" in warning_msgs[-1].message + assert "Detected default boot kernel {}".format(old_kernel) in warning_msgs[-1].message (filename, content), _ = utils.store_content_to_file.call_args kernel_file_lines = content.splitlines() @@ -450,7 +450,7 @@ def test_fix_default_kernel_with_no_incorrect_kernel( debug_records = [m for m in caplog.records if m.levelname == "DEBUG"] assert not warning_records - assert any("Boot kernel validated." in r.message for r in debug_records) + assert any("The default boot kernel is correct." in r.message for r in debug_records) for record in info_records: assert not re.search("Boot kernel [^ ]\\+ was changed to [^ ]\\+", record.message) diff --git a/convert2rhel/unit_tests/actions/post_conversion/hostmetering_test.py b/convert2rhel/unit_tests/actions/post_conversion/hostmetering_test.py index 747ef1fec4..6a711e9dee 100644 --- a/convert2rhel/unit_tests/actions/post_conversion/hostmetering_test.py +++ b/convert2rhel/unit_tests/actions/post_conversion/hostmetering_test.py @@ -167,7 +167,7 @@ def test_configure_host_metering( hostmetering_instance, level="ERROR", id="HOST_METERING_NOT_RUNNING", - title="Host metering service is not running.", + title="Host metering service is not running", description="host-metering.service is not running.", remediations="You can try to start the service manually" " by running following command:\n" @@ -209,9 +209,9 @@ def test_configure_host_metering( level="WARNING", id="FORCED_CONFIGURE_HOST_METERING", title="Configuration of host metering set to 'force'", - description="Please note that this option is mainly used for testing and" + description="Note that this option is mainly used for testing and" " will configure host-metering unconditionally." - " For generic usage please use the 'auto' option.", + " For generic usage use the 'auto' option.", ) }, actions.ActionResult(level="SUCCESS", id="SUCCESS"), @@ -253,23 +253,21 @@ def test_configure_host_metering( ("yum install fail", 1), ("", ""), None, - set( - ( - actions.ActionMessage( - level="WARNING", - id="INSTALL_HOST_METERING_FAILURE", - title="Failed to install host metering package.", - description="When installing host metering package an error occurred meaning we can't" - " enable host metering on the system.", - diagnosis="`yum install host-metering` command returned 1 with message yum install fail", - remediations="You can try install and set up the host metering" - " manually using following commands:\n" - " - `yum install host-metering`\n" - " - `systemctl enable host-metering.service`\n" - " - `systemctl start host-metering.service`", - ), + { + actions.ActionMessage( + level="WARNING", + id="INSTALL_HOST_METERING_FAILURE", + title="Failed to install the host-metering package", + description="When installing the host-metering package an error occurred meaning we can't" + " enable host metering on the system.", + diagnosis="`yum install host-metering` command returned 1 with message yum install fail", + remediations="You can try install and set up the host metering" + " manually using following commands:\n" + " - `yum install host-metering`\n" + " - `systemctl enable host-metering.service`\n" + " - `systemctl start host-metering.service`", ) - ), + }, actions.ActionResult(level="SUCCESS", id="SUCCESS"), ), ( @@ -279,22 +277,20 @@ def test_configure_host_metering( ("", 0), ("systemctl enable host-metering.service", "Failed to enable"), None, - set( - ( - actions.ActionMessage( - level="WARNING", - id="CONFIGURE_HOST_METERING_FAILURE", - title="Failed to enable and start host metering service.", - description="The host metering service failed to start" - " successfully and won't be able to keep track.", - diagnosis="Command systemctl enable host-metering.service failed with Failed to enable", - remediations="You can try set up the host metering" - " service manually using following commands:\n" - " - `systemctl enable host-metering.service`\n" - " - `systemctl start host-metering.service`", - ), + { + actions.ActionMessage( + level="WARNING", + id="CONFIGURE_HOST_METERING_FAILURE", + title="Failed to enable and start the host metering service", + description="The host metering service failed to start successfully and won't" + " be able to report on the use of the system for the billing purposes.", + diagnosis="Command systemctl enable host-metering.service failed with Failed to enable", + remediations="You can try set up the host metering" + " service manually using following commands:\n" + " - `systemctl enable host-metering.service`\n" + " - `systemctl start host-metering.service`", ) - ), + }, actions.ActionResult(level="SUCCESS", id="SUCCESS"), ), ( @@ -308,7 +304,7 @@ def test_configure_host_metering( actions.ActionResult( level="ERROR", id="HOST_METERING_NOT_RUNNING", - title="Host metering service is not running.", + title="Host metering service is not running", description="host-metering.service is not running.", remediations="You can try to start the service manually" " by running following command:\n" diff --git a/convert2rhel/unit_tests/actions/post_conversion/modified_rpm_files_diff_test.py b/convert2rhel/unit_tests/actions/post_conversion/modified_rpm_files_diff_test.py index 5a29e1919e..b0ad28bdbc 100644 --- a/convert2rhel/unit_tests/actions/post_conversion/modified_rpm_files_diff_test.py +++ b/convert2rhel/unit_tests/actions/post_conversion/modified_rpm_files_diff_test.py @@ -50,7 +50,7 @@ def test_modified_rpm_files_diff_with_no_rpm_va( actions.ActionMessage( level="INFO", id="SKIPPED_MODIFIED_RPM_FILES_DIFF", - title="Skipped comparison of 'rpm -Va' output from before and after the conversion.", + title="Skipped comparison of 'rpm -Va' output from before and after the conversion", description="Comparison of 'rpm -Va' output was not performed due to missing output " "of the 'rpm -Va' run before the conversion.", diagnosis="This is caused mainly by using '--no-rpm-va' argument for convert2rhel.", @@ -81,7 +81,7 @@ def test_modified_rpm_files_diff_with_no_rpm_va( actions.ActionMessage( level="INFO", id="FOUND_MODIFIED_RPM_FILES", - title="Modified rpm files from before and after the conversion were found.", + title="Modified rpm files from before and after the conversion were found", description="Comparison of modified rpm files from before and after the conversion: \n" "--- {path}/rpm_va.log\n" "+++ {path}/rpm_va_after_conversion.log\n" diff --git a/convert2rhel/unit_tests/actions/post_conversion/remove_tmp_dir_test.py b/convert2rhel/unit_tests/actions/post_conversion/remove_tmp_dir_test.py index 64377157f7..368fe2e36e 100644 --- a/convert2rhel/unit_tests/actions/post_conversion/remove_tmp_dir_test.py +++ b/convert2rhel/unit_tests/actions/post_conversion/remove_tmp_dir_test.py @@ -63,7 +63,7 @@ def test_remove_tmp_dir_failure(remove_tmp_dir_instance, monkeypatch, tmpdir, ca actions.ActionMessage( id="UNSUCCESSFUL_REMOVE_TMP_DIR", level="WARNING", - title="Temporary folder {tmp_dir} wasn't removed.".format(tmp_dir=path), + title="Temporary folder {tmp_dir} wasn't removed".format(tmp_dir=path), description=expected_message, ), ), diff --git a/convert2rhel/unit_tests/actions/post_conversion/update_grub_test.py b/convert2rhel/unit_tests/actions/post_conversion/update_grub_test.py index 4d94eaedfe..e636166b64 100644 --- a/convert2rhel/unit_tests/actions/post_conversion/update_grub_test.py +++ b/convert2rhel/unit_tests/actions/post_conversion/update_grub_test.py @@ -244,6 +244,6 @@ def test_update_grub_error(update_grub_instance, monkeypatch, get_partition_erro level="ERROR", id="FAILED_TO_IDENTIFY_GRUB2_BLOCK_DEVICE", title="Failed to identify GRUB2 block device", - description="The block device could not be identified, please look at the diagnosis " "for more information.", + description="The block device could not be identified. Look at the diagnosis for more information.", diagnosis=diagnosis, ) diff --git a/convert2rhel/unit_tests/actions/pre_ponr_changes/backup_system_test.py b/convert2rhel/unit_tests/actions/pre_ponr_changes/backup_system_test.py index 5ad69a351f..7e84e2ff16 100644 --- a/convert2rhel/unit_tests/actions/pre_ponr_changes/backup_system_test.py +++ b/convert2rhel/unit_tests/actions/pre_ponr_changes/backup_system_test.py @@ -95,7 +95,7 @@ def test_backup_redhat_release_calls(self, backup_redhat_release_action, monkeyp def test_backup_redhat_release_error_system_release_file(self, backup_redhat_release_action, monkeypatch): mock_sys_release_file = RestorableFileBackupMocked( id_="FAILED_TO_SAVE_FILE_TO_BACKUP_DIR", - title="Failed to copy file to the backup directory.", + title="Failed to copy file to the backup directory", description="Failure while backing up a file.", diagnosis="Failed to backup /etc/system-release. Errno: 2, Error: File not found", ) @@ -107,7 +107,7 @@ def test_backup_redhat_release_error_system_release_file(self, backup_redhat_rel backup_redhat_release_action, level="ERROR", id="FAILED_TO_SAVE_FILE_TO_BACKUP_DIR", - title="Failed to copy file to the backup directory.", + title="Failed to copy file to the backup directory", description="Failure while backing up a file.", diagnosis="Failed to backup /etc/system-release. Errno: 2, Error: File not found", ) @@ -116,7 +116,7 @@ def test_backup_redhat_release_error_os_release_file(self, backup_redhat_release mock_sys_release_file = mock.create_autospec(backup_system.system_release_file.enable) mock_os_release_file = RestorableFileBackupMocked( id_="FAILED_TO_SAVE_FILE_TO_BACKUP_DIR", - title="Failed to copy file to the backup directory.", + title="Failed to copy file to the backup directory", description="Failure while backing up a file.", diagnosis="Failed to backup /etc/os-release. Errno: 2, Error: File not found", ) @@ -130,7 +130,7 @@ def test_backup_redhat_release_error_os_release_file(self, backup_redhat_release backup_redhat_release_action, level="ERROR", id="FAILED_TO_SAVE_FILE_TO_BACKUP_DIR", - title="Failed to copy file to the backup directory.", + title="Failed to copy file to the backup directory", description="Failure while backing up a file.", diagnosis="Failed to backup /etc/os-release. Errno: 2, Error: File not found", ) @@ -176,7 +176,7 @@ def test_backup_redhat_release_error_os_release_file(self, backup_redhat_release ( "S.5.?..5. /etc/yum.repos.d/CentOS-Linux-AppStream.repo", [], - "Skipping invalid output S.5.?..5. /etc/yum.repos.d/CentOS-Linux-AppStream.repo", + "Skipping invalid output: S.5.?..5. /etc/yum.repos.d/CentOS-Linux-AppStream.repo", ), ( " ", @@ -186,21 +186,21 @@ def test_backup_redhat_release_error_os_release_file(self, backup_redhat_release ( "SM5DLUGTP cd /etc/yum.repos.d/CentOS-Linux-AppStream.repo", [], - "Skipping invalid output SM5DLUGTP cd /etc/yum.repos.d/CentOS-Linux-AppStream.repo", + "Skipping invalid output: SM5DLUGTP cd /etc/yum.repos.d/CentOS-Linux-AppStream.repo", ), ( """c /etc/yum.repos.d/CentOS-Linux-AppStream.repo S.5.?..T. c """, [], - "Skipping invalid output c /etc/yum.repos.d/CentOS-Linux-AppStream.repo", + "Skipping invalid output: c /etc/yum.repos.d/CentOS-Linux-AppStream.repo", ), ( """ S.5.?..T. c """, [], - "Skipping invalid output S.5.?..T. c", + "Skipping invalid output: S.5.?..T. c", ), ), ) @@ -239,7 +239,7 @@ def test_get_changed_package_file_system_exit( monkeypatch.setattr(backup_system, "LOG_DIR", str(tmp_path)) rpm_va_path = os.path.join(tmp_path, PRE_RPM_VA_LOG_FILENAME) - message = "Missing file {} in it's location".format(rpm_va_path) + message = "The file {} is missing.".format(rpm_va_path) with pytest.raises(SystemExit, match=message): backup_package_files_action._get_changed_package_files() diff --git a/convert2rhel/unit_tests/actions/pre_ponr_changes/custom_repos_are_valid_test.py b/convert2rhel/unit_tests/actions/pre_ponr_changes/custom_repos_are_valid_test.py index 1936f9e79b..042ac63784 100644 --- a/convert2rhel/unit_tests/actions/pre_ponr_changes/custom_repos_are_valid_test.py +++ b/convert2rhel/unit_tests/actions/pre_ponr_changes/custom_repos_are_valid_test.py @@ -62,7 +62,7 @@ def test_custom_repos_are_invalid(custom_repos_are_valid_action, monkeypatch): id="UNABLE_TO_ACCESS_REPOSITORIES", title="Unable to access repositories", description="Access could not be made to the custom repositories.", - diagnosis="Unable to access the repositories passed through the --enablerepo option.", + diagnosis="Unable to access repositories passed through the --enablerepo option.", remediations="For more details, see YUM/DNF output:\nYUM/DNF failed", ) @@ -72,7 +72,4 @@ def test_custom_repos_are_valid_skip(custom_repos_are_valid_action, monkeypatch, custom_repos_are_valid_action.run() - assert ( - "Did not perform the check of repositories due to the use of RHSM for the conversion." - in caplog.records[-1].message - ) + assert "Skipping the check verifying the accessibility of the repositories." in caplog.records[-1].message diff --git a/convert2rhel/unit_tests/actions/pre_ponr_changes/handle_packages_test.py b/convert2rhel/unit_tests/actions/pre_ponr_changes/handle_packages_test.py index 1333bd8bee..b9e4eeba73 100644 --- a/convert2rhel/unit_tests/actions/pre_ponr_changes/handle_packages_test.py +++ b/convert2rhel/unit_tests/actions/pre_ponr_changes/handle_packages_test.py @@ -168,7 +168,7 @@ def test_dependency_order(self, remove_special_packages_instance): def test_run_no_packages_to_remove(self, monkeypatch, remove_special_packages_instance, caplog): monkeypatch.setattr(pkghandler, "get_packages_to_remove", GetPackagesToRemoveMocked(return_value=[])) remove_special_packages_instance.run() - assert "No packages to backup and remove." in caplog.records[-1].message + assert "No packages to back up and remove." in caplog.records[-1].message def test_run_all_removed(self, monkeypatch, remove_special_packages_instance): pkgs_to_remove = [get_centos_logos_pkg_object()] @@ -212,7 +212,7 @@ def test_run_packages_not_removed(self, pretend_os, monkeypatch, remove_special_ level="WARNING", id="SPECIAL_PACKAGES_NOT_REMOVED", title="Special packages not removed", - description="Special packages which could not be removed", + description="Certain packages could not be removed.", diagnosis="The following packages were not removed: gpg-pubkey-1.0.0-1.x86_64, pkg1-None-None.None, pkg2-None-None.None", remediations=None, variables={}, @@ -256,8 +256,8 @@ def test_run_packages_error(self, monkeypatch, remove_special_packages_instance) remove_special_packages_instance, level="ERROR", id="SPECIAL_PACKAGE_REMOVAL_FAILED", - title="Failed to remove some packages necessary for the conversion.", - description="The cause of this error is unknown, please look at the diagnosis for more information.", + title="Failed to remove some packages necessary for the conversion", + description="The cause of this error is unknown. Look at the diagnosis for more information.", diagnosis="Raising SystemExit", ) diff --git a/convert2rhel/unit_tests/actions/pre_ponr_changes/kernel_modules_test.py b/convert2rhel/unit_tests/actions/pre_ponr_changes/kernel_modules_test.py index 9e3ee44e7b..c70f9c1d91 100644 --- a/convert2rhel/unit_tests/actions/pre_ponr_changes/kernel_modules_test.py +++ b/convert2rhel/unit_tests/actions/pre_ponr_changes/kernel_modules_test.py @@ -162,7 +162,7 @@ def test_ensure_compatibility_of_kmods( ), ( HOST_MODULES_STUB_BAD, - "kernel-core-0:4.18.0-240.10.1.el8_3.x86_64\n" "kernel-core-0:4.19.0-240.10.1.el8_3.i486\n", + "kernel-core-0:4.18.0-240.10.1.el8_3.x86_64\nkernel-core-0:4.19.0-240.10.1.el8_3.i486\n", ("", 0), "CANNOT_COMPARE_PACKAGE_VERSIONS", "ERROR", @@ -238,7 +238,7 @@ def test_ensure_compatibility_of_kmods_check_env_and_message( message = ensure_kernel_modules_compatibility_instance.messages[0] assert STATUS_CODE["WARNING"] == message.level assert "ALLOW_UNAVAILABLE_KERNEL_MODULES" == message.id - assert "Did not perform the ensure kernel modules compatibility check" == message.title + assert "Ignoring the check ensuring kernel module availability in RHEL" == message.title assert ( "We will continue the conversion with the following kernel modules unavailable in RHEL:" in message.description ) @@ -315,7 +315,7 @@ def test_ensure_compatibility_of_kmods_excluded( level="OVERRIDABLE", id="UNSUPPORTED_KERNEL_MODULES", title="Unsupported kernel modules", - description="Unsupported kernel modules were found", + description="Unsupported kernel modules were found.", diagnosis="The following loaded kernel modules are not available in RHEL:", remediations="Ensure you have updated the kernel to the latest available version and rebooted the system.", ) diff --git a/convert2rhel/unit_tests/actions/pre_ponr_changes/subscription_test.py b/convert2rhel/unit_tests/actions/pre_ponr_changes/subscription_test.py index 29c0072d63..6b45fa57b2 100644 --- a/convert2rhel/unit_tests/actions/pre_ponr_changes/subscription_test.py +++ b/convert2rhel/unit_tests/actions/pre_ponr_changes/subscription_test.py @@ -294,7 +294,7 @@ def test_subscribe_system_not_registered(self, global_tool_opts, subscribe_syste level="ERROR", id="SYSTEM_NOT_REGISTERED", title="Not registered with RHSM", - description="This system must be registered with rhsm in order to get access to the RHEL rpms. In this case, the system was not already registered and no credentials were given to convert2rhel to register it.", + description="This system must be registered with RHSM in order to get access to RHEL rpms. In this case, the system has not been registered and no credentials were given to convert2rhel to register it.", remediations="You may either register this system via subscription-manager before running convert2rhel or give convert2rhel credentials to do that for you. The credentials convert2rhel would need are either activation_key and organization or username and password. You can set these in a config file and then pass the file to convert2rhel with the --config-file option.", ) diff --git a/convert2rhel/unit_tests/actions/system_checks/check_firewalld_availability_test.py b/convert2rhel/unit_tests/actions/system_checks/check_firewalld_availability_test.py index 140c38d5fa..0a14f3c03f 100644 --- a/convert2rhel/unit_tests/actions/system_checks/check_firewalld_availability_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/check_firewalld_availability_test.py @@ -169,6 +169,16 @@ def test_is_modules_cleanup_enabled(monkeypatch, write_firewalld_mockup_config, True, True, ), + ( + { + "content": """ +#CleanupModulesOnExit=yes +CleanupModulesOnExit=no +""" + }, + True, + False, + ), ), indirect=("write_firewalld_mockup_config",), ) @@ -183,8 +193,10 @@ def test_is_modules_cleanup_config_commented( "Couldn't find CleanupModulesOnExit in firewalld.conf. Treating it as enabled because of default behavior." in caplog.records[-1].message ) + elif expected: + assert "CleanupModulesOnExit option is enabled in " in caplog.records[-1].message else: - assert "CleanupModulesOnExit option enabled" in caplog.records[-1].message + assert "CleanupModulesOnExit option is disabled in " in caplog.records[-1].message @pytest.mark.skipif(pkgmanager.TYPE == "yum", reason="Test is only relevant for RHEL 8+") @@ -299,7 +311,7 @@ def test_cleanup_modules_on_exit_is_true( check_firewalld_availability_is_running_action, level="ERROR", id="FIREWALLD_MODULES_CLEANUP_ON_EXIT_CONFIG", - title="Firewalld is set to cleanup modules after exit.", + title="Firewalld is set to cleanup modules after exit", description="Firewalld running on Oracle Linux 8 can lead to a conversion failure.", diagnosis=( "We've detected that firewalld unit is running and that causes iptables and nftables " diff --git a/convert2rhel/unit_tests/actions/system_checks/convert2rhel_latest_test.py b/convert2rhel/unit_tests/actions/system_checks/convert2rhel_latest_test.py index dc3b973ff7..23ec06f5d6 100644 --- a/convert2rhel/unit_tests/actions/system_checks/convert2rhel_latest_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/convert2rhel_latest_test.py @@ -146,7 +146,7 @@ class TestCheckConvert2rhelLatest: def test_convert2rhel_latest_outdated_version_inhibitor( self, convert2rhel_latest_action_instance, prepare_convert2rhel_latest_action, monkeypatch, global_tool_opts ): - """When runnnig on a supported major version, we issue an error = inhibitor.""" + """When running on a supported major version, we issue an error = inhibitor.""" monkeypatch.setattr(convert2rhel_latest, "tool_opts", global_tool_opts) convert2rhel_latest_action_instance.run() @@ -157,6 +157,7 @@ def test_convert2rhel_latest_outdated_version_inhibitor( level="OVERRIDABLE", id="OUT_OF_DATE", title="Outdated convert2rhel version detected", + description="An outdated convert2rhel version has been detected.", diagnosis=( "You are currently running {} and the latest version of convert2rhel is {}.\n" "Only the latest version is supported for conversion.".format(running_version, latest_version) @@ -415,7 +416,7 @@ def test_convert2rhel_latest_repoquery_error( level="WARNING", id="CONVERT2RHEL_LATEST_CHECK_SKIP", title="convert2rhel latest version check skip", - description="Did not perform the convert2hel latest version check", + description="Did not perform the convert2hel latest version check.", diagnosis=( "Couldn't check if the current installed convert2rhel is the latest version.\n" "repoquery failed with the following output:\nRepoquery did not run" @@ -475,9 +476,11 @@ def test_convert2rhel_latest_repoquery_error( ), indirect=True, ) - def ttest_convert2rhel_latest_multiple_packages( - self, convert2rhel_latest_action_instance, prepare_convert2rhel_latest_action + def test_convert2rhel_latest_multiple_packages( + self, convert2rhel_latest_action_instance, prepare_convert2rhel_latest_action, monkeypatch, global_tool_opts ): + monkeypatch.setattr(convert2rhel_latest, "tool_opts", global_tool_opts) + convert2rhel_latest_action_instance.run() running_version, latest_version = prepare_convert2rhel_latest_action @@ -487,12 +490,13 @@ def ttest_convert2rhel_latest_multiple_packages( level="OVERRIDABLE", id="OUT_OF_DATE", title="Outdated convert2rhel version detected", - description="An outdated convert2rhel version has been detected", + description="An outdated convert2rhel version has been detected.", diagnosis=( "You are currently running {} and the latest version of convert2rhel is {}.\n" "Only the latest version is supported for conversion.".format(running_version, latest_version) ), - remediations="If you want to disregard this check, then set the environment variable 'CONVERT2RHEL_ALLOW_OLDER_VERSION=1' to continue.", + remediations="If you want to disregard this check, set the allow_older_version inhibitor" + " override in the /etc/convert2rhel.ini config file to true.", ) @pytest.mark.parametrize( @@ -673,7 +677,7 @@ def test_convert2rhel_latest_bad_nevra_to_parse_pkg_string( level="OVERRIDABLE", id="OUT_OF_DATE", title="Outdated convert2rhel version detected", - description="An outdated convert2rhel version has been detected", + description="An outdated convert2rhel version has been detected.", diagnosis=( "You are currently running {} and the latest version of convert2rhel is {}.\n" "Only the latest version is supported for conversion.".format(running_version, latest_version) diff --git a/convert2rhel/unit_tests/actions/system_checks/dbus_test.py b/convert2rhel/unit_tests/actions/system_checks/dbus_test.py index 390f7a0223..644fc40bce 100644 --- a/convert2rhel/unit_tests/actions/system_checks/dbus_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/dbus_test.py @@ -31,7 +31,7 @@ def dbus_is_running_action(): ( (False, True, "Did not perform the check because we have been asked not to subscribe this system to RHSM."), (False, False, "Did not perform the check because we have been asked not to subscribe this system to RHSM."), - (True, True, "DBus Daemon is running"), + (True, True, "DBus daemon is running."), ), ) def test_check_dbus_is_running( @@ -58,7 +58,7 @@ def test_check_dbus_is_running_not_running(monkeypatch, global_system_info, dbus dbus_is_running_action, level="ERROR", id="DBUS_DAEMON_NOT_RUNNING", - description="The Dbus daemon is not running", + description="The Dbus daemon is not running.", diagnosis="Could not find a running DBus Daemon which is needed to register with subscription manager.", - remediations="Please start dbus using `systemctl start dbus`", + remediations="Start dbus using `systemctl start dbus`", ) diff --git a/convert2rhel/unit_tests/actions/system_checks/efi_test.py b/convert2rhel/unit_tests/actions/system_checks/efi_test.py index de13ac77ed..6fe2928866 100644 --- a/convert2rhel/unit_tests/actions/system_checks/efi_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/efi_test.py @@ -100,7 +100,7 @@ class TestEFIChecks: ExpectedMessage( id="BOOTLOADER_ERROR", title="Bootloader error detected", - description="An unknown bootloader error occurred, please look at the diagnosis for more information.", + description="An unknown bootloader error occurred. Look at the diagnosis for more information.", diagnosis="errmsg", remediations="", log_msg="", diff --git a/convert2rhel/unit_tests/actions/system_checks/els_test.py b/convert2rhel/unit_tests/actions/system_checks/els_test.py index 1ee0f2e48d..c68079ac1a 100644 --- a/convert2rhel/unit_tests/actions/system_checks/els_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/els_test.py @@ -49,7 +49,9 @@ class TestEus: (Version(9, 2), False), ), ) - def test_els_warning_message(self, els_action, monkeypatch, global_tool_opts, version_string, message_reported): + def test_els_warning_message( + self, els_action, monkeypatch, global_tool_opts, version_string, message_reported, caplog + ): global_tool_opts.els = False monkeypatch.setattr(system_info, "version", version_string) monkeypatch.setattr(systeminfo, "tool_opts", global_tool_opts) @@ -62,8 +64,9 @@ def test_els_warning_message(self, els_action, monkeypatch, global_tool_opts, ve level="WARNING", id="ELS_COMMAND_LINE_OPTION_UNUSED", title="The --els command line option is unused", - description="Current system version is under Extended Lifecycle Support (ELS). You may want to consider using the --els" - " command line option to land on a system patched with the latest security errata.", + description="Current system version is under Extended Lifecycle Support (ELS). You may want to" + " consider using the --els command line option to land on a system patched with the latest security" + " errata.", ), ) ) @@ -73,3 +76,4 @@ def test_els_warning_message(self, els_action, monkeypatch, global_tool_opts, ve assert expected.issubset(els_action.messages) else: assert els_action.messages == [] + "Applicable only to conversions to RHEL 7." in caplog.records[-1].message diff --git a/convert2rhel/unit_tests/actions/system_checks/eus_test.py b/convert2rhel/unit_tests/actions/system_checks/eus_test.py index 0f13be28d4..1015372767 100644 --- a/convert2rhel/unit_tests/actions/system_checks/eus_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/eus_test.py @@ -18,8 +18,11 @@ import datetime import pytest +import six -from convert2rhel import actions, pkgmanager, systeminfo +six.add_move(six.MovedModule("mock", "mock", "unittest.mock")) + +from convert2rhel import actions, systeminfo from convert2rhel.actions.system_checks import eus from convert2rhel.systeminfo import Version, system_info @@ -30,9 +33,13 @@ def eus_action(): class DateMock(datetime.date): + @classmethod + def set_today(cls, today_date): + cls.today_date = today_date + @classmethod def today(cls): - return cls(2023, 11, 15) + return cls.today_date @pytest.fixture(autouse=True) @@ -42,34 +49,41 @@ def apply_global_tool_opts(monkeypatch, global_tool_opts): class TestEus: @pytest.mark.parametrize( - ("version_string", "message_reported"), + ("system_version", "today_date", "message_reported"), ( - (Version(8, 8), True), - (Version(9, 2), False), # Change to True after 9.2 is under eus + (Version(7, 9), datetime.date(2024, 12, 4), False), + (Version(8, 8), datetime.date(2023, 11, 13), False), + (Version(8, 8), datetime.date(2023, 11, 15), True), + (Version(9, 2), datetime.date(2024, 12, 4), False), ), ) - @pytest.mark.skipif(pkgmanager.TYPE != "dnf", reason="el7 systems are not under eus") - def test_eus_warning_message(self, eus_action, monkeypatch, global_tool_opts, version_string, message_reported): + def test_eus_warning_message( + self, eus_action, monkeypatch, global_tool_opts, system_version, today_date, message_reported, caplog + ): global_tool_opts.eus = False - monkeypatch.setattr(system_info, "version", version_string) + monkeypatch.setattr(system_info, "version", system_version) monkeypatch.setattr(systeminfo, "tool_opts", global_tool_opts) monkeypatch.setattr(eus.datetime, "date", DateMock) + monkeypatch.setattr(systeminfo, "EUS_MINOR_VERSIONS", {"8.8": "2023-11-14"}) + eus.datetime.date.set_today(today_date) eus_action.run() - expected = set( - ( - actions.ActionMessage( - level="WARNING", - id="EUS_COMMAND_LINE_OPTION_UNUSED", - title="The --eus command line option is unused", - description="Current system version is under Extended Update Support (EUS). You may want to consider using the --eus" - " command line option to land on a system patched with the latest security errata.", - ), + expected = { + actions.ActionMessage( + level="WARNING", + id="EUS_COMMAND_LINE_OPTION_UNUSED", + title="The --eus command line option is unused", + description="Current system version is under Extended Update Support (EUS). You may want to" + " consider using the --eus command line option to land on a system patched with the latest" + " security errata.", ) - ) + } if message_reported: assert expected.issuperset(eus_action.messages) assert expected.issubset(eus_action.messages) else: assert eus_action.messages == [] + "Applicable only when converting the following system versions:\n8.8 after 2023-11-14" in caplog.records[ + -1 + ].message diff --git a/convert2rhel/unit_tests/actions/system_checks/grub_validity_test.py b/convert2rhel/unit_tests/actions/system_checks/grub_validity_test.py index afb34337c3..1e0fc53860 100644 --- a/convert2rhel/unit_tests/actions/system_checks/grub_validity_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/grub_validity_test.py @@ -30,17 +30,26 @@ def grub_validity_instance(): return grub_validity.GrubValidity() -def test_grub_validity_error(grub_validity_instance, monkeypatch): - monkeypatch.setattr(utils, "run_subprocess", RunSubprocessMocked(return_value=("output", 127))) +@pytest.mark.parametrize( + ("mkconfig_ret_code", "mkconfig_output"), + ( + (0, "generated grub configuration"), + (1, "reported errors"), + ), +) +def test_grub_validity_error(grub_validity_instance, monkeypatch, mkconfig_ret_code, mkconfig_output, caplog): + monkeypatch.setattr(utils, "run_subprocess", RunSubprocessMocked(return_value=(mkconfig_output, mkconfig_ret_code))) grub_validity_instance.run() - unit_tests.assert_actions_result( - grub_validity_instance, - level="ERROR", - id="INVALID_GRUB_FILE", - title="Grub boot entry file is invalid", - description="The grub file seems to be invalid leaving the system in a" - " non-clean state and must be fixed before continuing the conversion" - " to ensure a smooth process.", - remediations="Check the grub file inside `/etc/default` directory and remove any " - "misconfigurations, then re-run the conversion.", - ) + if mkconfig_ret_code != 0: + unit_tests.assert_actions_result( + grub_validity_instance, + level="ERROR", + id="INVALID_GRUB_FILE", + title="/etc/default/grub invalid", + description="The /etc/default/grub file seems to be invalid and must be fixed before continuing the" + "conversion.", + diagnosis="Calling grub2-mkconfig failed with:\n{}".format(mkconfig_output), + remediations="Fix issues reported by the grub2-mkconfig utility and re-run the conversion.", + ) + else: + "No issues found with the /etc/default/grub file." in caplog.records[-1].message diff --git a/convert2rhel/unit_tests/actions/system_checks/is_loaded_kernel_latest_test.py b/convert2rhel/unit_tests/actions/system_checks/is_loaded_kernel_latest_test.py index b6f8d2f627..8d7cff7b75 100644 --- a/convert2rhel/unit_tests/actions/system_checks/is_loaded_kernel_latest_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/is_loaded_kernel_latest_test.py @@ -119,7 +119,7 @@ def test_is_loaded_kernel_latest_eus_system_invalid_kernel_version( id="INVALID_KERNEL_VERSION", level="OVERRIDABLE", title="Invalid kernel version detected", - description="The loaded kernel version mismatch the latest one available in system repositories", + description="The loaded kernel version mismatch the latest one available in system repositories.", diagnosis="The version of the loaded kernel is different from the latest version in system repositories.", remediations="To proceed with the conversion, update the kernel version by executing the following step:\n\n", ) @@ -142,7 +142,7 @@ def test_is_loaded_kernel_latest_eus_system_invalid_kernel_version( 0, "kernel-core", "Invalid kernel package found", - "Please refer to the diagnosis for further information", + "Refer to the diagnosis for further information.", "The package names ('kernel-core-1' and 'kernel-core-2') do not match. Can only compare versions for the same packages.", None, ), @@ -152,7 +152,7 @@ def test_is_loaded_kernel_latest_eus_system_invalid_kernel_version( 0, "kernel-core", "Invalid kernel package found", - "Please refer to the diagnosis for further information", + "Refer to the diagnosis for further information.", "Invalid package - kernel-core-1 .01-5.02, packages need to be in one of the following formats: NEVRA, NEVR, NVRA, NVR, ENVRA, ENVR.", None, ), @@ -238,7 +238,7 @@ def test_is_loaded_kernel_latest_invalid_kernel_package_dnf( 0, "kernel", "Invalid kernel package found", - "Please refer to the diagnosis for further information", + "Refer to the diagnosis for further information.", "The following field(s) are invalid - release : 1.01-5", None, ), @@ -248,7 +248,7 @@ def test_is_loaded_kernel_latest_invalid_kernel_package_dnf( 0, "kernel", "Invalid kernel package found", - "Please refer to the diagnosis for further information", + "Refer to the diagnosis for further information.", "The following field(s) are invalid - version : 1 .01", None, ), @@ -426,18 +426,16 @@ def test_is_loaded_kernel_latest_skip_warnings( {"CONVERT2RHEL_SKIP_KERNEL_CURRENCY_CHECK": skip_check}, ) - expected_set = set( - ( - actions.ActionMessage( - level=level, - id=id, - title=title, - description=description, - diagnosis=diagnosis, - remediations=remediations, - ), + expected_set = { + actions.ActionMessage( + level=level, + id=id, + title=title, + description=description, + diagnosis=diagnosis, + remediations=remediations, ) - ) + } is_loaded_kernel_latest_action.run() assert description in caplog.records[-1].message assert expected_set.issuperset(is_loaded_kernel_latest_action.messages) @@ -464,7 +462,7 @@ def test_is_loaded_kernel_latest_skip_warnings( "Unable to fetch recent kernels", ( "Couldn't fetch the list of the most recent kernels available in " - "the repositories. Did not perform the loaded kernel check." + "the repositories. Did not perform the loaded kernel currency check." ), None, None, @@ -549,10 +547,10 @@ def test_is_loaded_kernel_latest_unable_to_fetch_kernels( 0, "kernel-core", "Kernel currency check failed", - "Please refer to the diagnosis for further information", + "Refer to the diagnosis for further information.", "Could not find any {0} from repositories to compare against the loaded kernel.", ( - "Please check if you have any vendor repositories enabled to proceed with the conversion.\n" + "Check if you have any vendor repositories enabled to proceed with the conversion.\n" "If you wish to disregard this message, set the skip_kernel_currency_check inhibitor override in" " the /etc/convert2rhel.ini config file to true." ), @@ -775,7 +773,7 @@ def test_is_loaded_kernel_latest_system_exit(self, monkeypatch, is_loaded_kernel level="OVERRIDABLE", id="INVALID_KERNEL_VERSION", title="Invalid kernel version detected", - description="The loaded kernel version mismatch the latest one available in system repositories", + description="The loaded kernel version mismatch the latest one available in system repositories.", diagnosis="The version of the loaded kernel is different from the latest version in system repositories.", remediations="To proceed with the conversion, update the kernel version by executing the following step:", ) diff --git a/convert2rhel/unit_tests/actions/system_checks/package_updates_test.py b/convert2rhel/unit_tests/actions/system_checks/package_updates_test.py index 16e829946b..93274bcad2 100644 --- a/convert2rhel/unit_tests/actions/system_checks/package_updates_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/package_updates_test.py @@ -46,7 +46,7 @@ def test_check_package_updates_skip_on_not_latest_ol(pretend_os, caplog, package level="INFO", id="PACKAGE_UPDATES_CHECK_SKIP_NO_PUBLIC_REPOSITORIES", title="Did not perform the package updates check", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=diagnosis, remediations=None, variables={}, @@ -77,7 +77,7 @@ def test_check_package_updates_not_up_to_date( packages = ["package-2", "package-1"] diagnosis = ( "The system has 2 package(s) not updated based on repositories defined in the system repositories.\n" - "List of packages to update: package-1 package-2.\n\n" + "List of packages to update: package-1 package-2\n\n" "Not updating the packages may cause the conversion to fail.\n" "Consider updating the packages before proceeding with the conversion." ) @@ -90,7 +90,7 @@ def test_check_package_updates_not_up_to_date( level="WARNING", id="OUT_OF_DATE_PACKAGES", title="Outdated packages detected", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=diagnosis, remediations="Run yum update to update all the packages on the system.", variables={}, @@ -118,7 +118,7 @@ def test_check_package_updates_with_repoerror_warning(pretend_os, monkeypatch, c level="WARNING", id="PACKAGE_UP_TO_DATE_CHECK_MESSAGE", title="Package up to date check fail", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=diagnosis, remediations=None, variables={}, diff --git a/convert2rhel/unit_tests/actions/system_checks/rhel_compatible_kernel_test.py b/convert2rhel/unit_tests/actions/system_checks/rhel_compatible_kernel_test.py index dc1a5b4ece..89b73bde7e 100644 --- a/convert2rhel/unit_tests/actions/system_checks/rhel_compatible_kernel_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/rhel_compatible_kernel_test.py @@ -80,7 +80,7 @@ def test_check_rhel_compatible_kernel_failure( level="ERROR", id="UNEXPECTED_VERSION", title="Incompatible booted kernel version", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis="The booted kernel version is incompatible with the standard RHEL kernel", remediations=( "To proceed with the conversion, boot into a kernel that is available in the {0} {1} base repository" diff --git a/convert2rhel/unit_tests/actions/system_checks/tainted_kmods_test.py b/convert2rhel/unit_tests/actions/system_checks/tainted_kmods_test.py index 3bc26a10c3..dee98e9b7e 100644 --- a/convert2rhel/unit_tests/actions/system_checks/tainted_kmods_test.py +++ b/convert2rhel/unit_tests/actions/system_checks/tainted_kmods_test.py @@ -71,7 +71,7 @@ def test_check_tainted_kmods(monkeypatch, command_return, is_error, tainted_kmod level="OVERRIDABLE", id="TAINTED_KMODS_DETECTED", title="Tainted kernel modules detected", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=( "Tainted kernel modules detected:\n system76_io\n system76_acpi\nThird-party " "components are not supported per our software support" @@ -84,7 +84,7 @@ def test_check_tainted_kmods(monkeypatch, command_return, is_error, tainted_kmod " tainted_kernel_module_check_skip inhibitor override in the /etc/convert2rhel.ini" " config file to true. Overriding this check can be dangerous" " so it is recommended that you do a system backup beforehand." - " For information on what a tainted kernel module is, please refer to this documentation {1}".format( + " For information on what a tainted kernel module is, refer to this documentation {1}".format( LINK_PREVENT_KMODS_FROM_LOADING, LINK_TAINTED_KMOD_DOCS ) ), @@ -128,7 +128,7 @@ def test_check_tainted_kmods_skip(monkeypatch, command_return, is_error, tainted level="WARNING", id="TAINTED_KMODS_DETECTED_MESSAGE", title="Tainted kernel modules detected", - description="Please refer to the diagnosis for further information", + description="Refer to the diagnosis for further information.", diagnosis=( "Tainted kernel modules detected:\n system76_io\n system76_acpi\nThird-party " "components are not supported per our software support" @@ -137,7 +137,7 @@ def test_check_tainted_kmods_skip(monkeypatch, command_return, is_error, tainted remediations=( "Prevent the modules from loading by following {0}" " and run convert2rhel again to continue with the conversion." - " For information on what a tainted kernel module is, please refer to this documentation {1}".format( + " For information on what a tainted kernel module is, refer to this documentation {1}".format( LINK_PREVENT_KMODS_FROM_LOADING, LINK_TAINTED_KMOD_DOCS ) ), diff --git a/convert2rhel/unit_tests/backup/files_test.py b/convert2rhel/unit_tests/backup/files_test.py index 2faa755bed..78273e9757 100644 --- a/convert2rhel/unit_tests/backup/files_test.py +++ b/convert2rhel/unit_tests/backup/files_test.py @@ -343,9 +343,9 @@ def test_created_file_enable(self, exists, expected, tmpdir, caplog, message): @pytest.mark.parametrize( ("exists", "enabled", "message"), ( - (True, True, "File {filepath} removed"), + (True, True, "File {filepath} removed."), (True, False, None), - (False, True, "File {filepath} wasn't created during conversion"), + (False, True, "File {filepath} wasn't created during conversion."), ), ) def test_created_file_restore(self, tmpdir, exists, enabled, message, caplog): @@ -371,13 +371,13 @@ def test_created_file_restore(self, tmpdir, exists, enabled, message, caplog): @pytest.mark.parametrize( ("exists", "created", "message_push", "message_pop"), ( - (False, True, "Marking file {filepath} as missing on system.", "File {filepath} removed"), + (False, True, "Marking file {filepath} as missing on system.", "File {filepath} removed."), (True, False, "The file {filepath} is present on the system before conversion, skipping it.", None), ( False, False, "Marking file {filepath} as missing on system.", - "File {filepath} wasn't created during conversion", + "File {filepath} wasn't created during conversion.", ), ), ) diff --git a/convert2rhel/unit_tests/backup/packages_test.py b/convert2rhel/unit_tests/backup/packages_test.py index 90515e2b7f..f14492d263 100644 --- a/convert2rhel/unit_tests/backup/packages_test.py +++ b/convert2rhel/unit_tests/backup/packages_test.py @@ -144,9 +144,9 @@ def test_restore_pkg_without_path(self, monkeypatch, caplog): with pytest.raises(exceptions.CriticalError) as err: rp.restore() - assert err.value.diagnosis == "Couldn't find a backup for test.rpm package." + assert err.value.diagnosis == "Couldn't find a backup for the following package(s): test.rpm" assert utils.remove_orphan_folders.call_count == 1 - assert "Couldn't find a backup for test.rpm package." in caplog.records[-1].message + assert "Couldn't find a backup for the following package(s): test.rpm" in caplog.records[-1].message def test_restore_second_restore(self, monkeypatch): monkeypatch.setattr( diff --git a/convert2rhel/unit_tests/backup/subscription_test.py b/convert2rhel/unit_tests/backup/subscription_test.py index 42ec3bcd40..fce7af3fb3 100644 --- a/convert2rhel/unit_tests/backup/subscription_test.py +++ b/convert2rhel/unit_tests/backup/subscription_test.py @@ -121,7 +121,7 @@ def test_restore_subman_uninstalled(self, caplog, monkeypatch, system_subscripti system_subscription.restore() - assert "subscription-manager not installed, skipping" == caplog.messages[-1] + assert "subscription-manager not installed, skipping." == caplog.messages[-1] class TestRestorableAutoAttachmentSubscription: diff --git a/convert2rhel/unit_tests/cli_test.py b/convert2rhel/unit_tests/cli_test.py index 8f15676cad..d8b07fdbf2 100644 --- a/convert2rhel/unit_tests/cli_test.py +++ b/convert2rhel/unit_tests/cli_test.py @@ -121,7 +121,7 @@ def test_bad_serverurl(self, caplog, monkeypatch, serverurl): message = ( "Failed to parse a valid subscription-manager server from the --serverurl option.\n" - "Please check for typos and run convert2rhel again with a corrected --serverurl.\n" + "Check for typos and run convert2rhel again with a corrected --serverurl.\n" "Supplied serverurl: {}\nError: ".format(serverurl) ) assert message in caplog.records[-1].message @@ -267,7 +267,7 @@ def test_no_rhsm_option_work(argv, no_rhsm_value, monkeypatch, global_tool_opts) activation_key = conf_key """, {"password": "password"}, - "You have passed the RHSM password without an associated username. Please provide a username together with the password.", + "You have passed the RHSM password without an associated username. Provide a username together with the password.", ), ( mock_cli_arguments(["-o", "org"]), @@ -597,11 +597,11 @@ def test_setting_no_rpm_va(argv, expected, message, monkeypatch, caplog, tmpdir) (mock_cli_arguments(["-u", "user", "-p", "pass"]), "-u ***** -p *****"), ( mock_cli_arguments(["-p", "pass"]), - "You have passed the RHSM password without an associated username. Please provide a username together with the password", + "You have passed the RHSM password without an associated username. Provide a username together with the password", ), ( mock_cli_arguments(["-u", "user"]), - "You have passed the RHSM username without an associated password. Please provide a password together with the username", + "You have passed the RHSM username without an associated password. Provide a password together with the username", ), ), ) diff --git a/convert2rhel/unit_tests/main_test.py b/convert2rhel/unit_tests/main_test.py index 996ce31ee3..5578249b58 100644 --- a/convert2rhel/unit_tests/main_test.py +++ b/convert2rhel/unit_tests/main_test.py @@ -65,15 +65,24 @@ def test_rollback_changes(self, monkeypatch, global_backup_control): assert global_backup_control.pop_all.call_args_list == mock.call() assert backup.backup_control.rollback_failed is False - def test_backup_control_unknown_exception(self, monkeypatch, global_backup_control): + @pytest.mark.parametrize( + ("index_error_arg", "log_instead_of_raise"), + (("Raised because of a bug in the code", False), ("No backups to restore", True)), + ) + def test_backup_control_exceptions( + self, monkeypatch, global_backup_control, index_error_arg, log_instead_of_raise, caplog + ): monkeypatch.setattr( global_backup_control, "pop_all", - mock.Mock(side_effect=IndexError("Raised because of a bug in the code")), + mock.Mock(side_effect=IndexError(index_error_arg)), ) - - with pytest.raises(IndexError, match="Raised because of a bug in the code"): + if log_instead_of_raise: main.rollback_changes() + "During rollback there were no backups to restore." in caplog.records[-1].message + else: + with pytest.raises(IndexError, match="Raised because of a bug in the code"): + main.rollback_changes() @pytest.mark.parametrize( ("pre_conversion_results", "include_all_reports", "rollback_failures", "message", "not_printed_message"), @@ -186,7 +195,7 @@ def test_initialize_file_logging(exception_type, exception, monkeypatch, caplog) if exception: assert caplog.records[-1].levelname == "WARNING" - assert "Unable to archive previous log:" in caplog.records[-1].message + assert "Unable to archive the previous log file:" in caplog.records[-1].message add_file_handler_mock.assert_called_once() archive_old_logger_files_mock.assert_called_once() diff --git a/convert2rhel/unit_tests/pkgmanager/handlers/dnf/dnf_test.py b/convert2rhel/unit_tests/pkgmanager/handlers/dnf/dnf_test.py index ceae3ac05d..727effe5f9 100644 --- a/convert2rhel/unit_tests/pkgmanager/handlers/dnf/dnf_test.py +++ b/convert2rhel/unit_tests/pkgmanager/handlers/dnf/dnf_test.py @@ -293,7 +293,7 @@ def test_resolve_dependencies(self, pretend_os, caplog, monkeypatch): assert pkgmanager.Base.resolve.call_count == 1 assert pkgmanager.Base.download_packages.call_count == 1 - assert "Resolving the dependencies of the packages in the dnf transaction set." in caplog.records[-2].message + assert "Resolving dependencies of the packages in the dnf transaction set." in caplog.records[-2].message @centos8 def test_resolve_dependencies_resolve_exception(self, pretend_os, caplog, monkeypatch): @@ -350,11 +350,11 @@ def test_process_transaction_exceptions(self, pretend_os, caplog): instance._process_transaction(validate_transaction=False) assert pkgmanager.Base.do_transaction.call_count == 1 - assert "Failed to validate the dnf transaction." in caplog.records[-1].message assert "FAILED_TO_VALIDATE_TRANSACTION" in execinfo._excinfo[1].id - assert "Failed to validate dnf transaction." in execinfo._excinfo[1].title + assert "Failed to validate a dnf transaction." in caplog.records[-1].message + assert "Failed to validate a dnf transaction" in execinfo._excinfo[1].title assert ( - "During the dnf transaction execution an error occured and convert2rhel could no longer process the transaction." + "During the dnf transaction execution an error occurred and convert2rhel could no longer process the transaction." in execinfo._excinfo[1].description ) assert ( @@ -364,7 +364,7 @@ def test_process_transaction_exceptions(self, pretend_os, caplog): @centos8 @pytest.mark.parametrize( - ("validate_transaction"), + "validate_transaction", ((True), (False)), ) def test_run_transaction(self, pretend_os, validate_transaction, caplog, monkeypatch): diff --git a/convert2rhel/unit_tests/pkgmanager/handlers/yum/yum_test.py b/convert2rhel/unit_tests/pkgmanager/handlers/yum/yum_test.py index f7575976f5..d18cf4bb16 100644 --- a/convert2rhel/unit_tests/pkgmanager/handlers/yum/yum_test.py +++ b/convert2rhel/unit_tests/pkgmanager/handlers/yum/yum_test.py @@ -248,9 +248,9 @@ def test_process_transaction_with_exceptions(self, pretend_os, caplog, monkeypat with pytest.raises(exceptions.CriticalError) as execinfo: instance._process_transaction(validate_transaction=False) - assert "Failed to validate the yum transaction." in caplog.records[-1].message assert "FAILED_TO_VALIDATE_TRANSACTION" in execinfo._excinfo[1].id - assert "Failed to validate yum transaction." in execinfo._excinfo[1].title + assert "Failed to validate a yum transaction." in caplog.records[-1].message + assert "Failed to validate a yum transaction" in execinfo._excinfo[1].title assert ( "During the yum transaction execution an error occurred and convert2rhel could no longer process the transaction." in execinfo._excinfo[1].description @@ -364,7 +364,7 @@ def test_run_transaction_reached_loop_max_attempts(self, pretend_os, monkeypatch with pytest.raises(exceptions.CriticalError): instance.run_transaction(True) - assert "Retrying to resolve dependencies 1" in caplog.records[-2].message + assert "Retrying to resolve dependencies - attempt 1." in caplog.records[-2].message assert "Failed to resolve dependencies in the transaction." in caplog.records[-1].message @centos7 diff --git a/convert2rhel/unit_tests/subscription_test.py b/convert2rhel/unit_tests/subscription_test.py index 56bbaa6225..ebe352c5f2 100644 --- a/convert2rhel/unit_tests/subscription_test.py +++ b/convert2rhel/unit_tests/subscription_test.py @@ -802,9 +802,7 @@ def test_registration_succeeds_but_dbus_returns_noreply(self, monkeypatch, mocke utils, "run_subprocess", RunSubprocessMocked( - return_string=( - "system identity: 1234-56-78-9abc\n" "name: abc-123\n" "org name: Test\n" "org ID: 12345678910\n" - ) + return_string=("system identity: 1234-56-78-9abc\nname: abc-123\norg name: Test\norg ID: 12345678910\n") ), ) diff --git a/convert2rhel/unit_tests/toolopts/toolopts_test.py b/convert2rhel/unit_tests/toolopts/toolopts_test.py index 95414eb614..178976e627 100644 --- a/convert2rhel/unit_tests/toolopts/toolopts_test.py +++ b/convert2rhel/unit_tests/toolopts/toolopts_test.py @@ -214,7 +214,7 @@ def test_handle_config_conflicts(config_sources, expected_message, expected_outp ), MockConfig(source="configuration file", username=None, org=None, activation_key=None, password=None), ], - "You have passed the RHSM password without an associated username. Please provide a username together" + "You have passed the RHSM password without an associated username. Provide a username together" " with the password.", ), # Config File - password without username @@ -231,7 +231,7 @@ def test_handle_config_conflicts(config_sources, expected_message, expected_outp ), MockConfig(source="configuration file", username=None, org=None, activation_key=None, password="test"), ], - "You have passed the RHSM password without an associated username. Please provide a username together" + "You have passed the RHSM password without an associated username. Provide a username together" " with the password.", ), # CLI - username without password @@ -248,7 +248,7 @@ def test_handle_config_conflicts(config_sources, expected_message, expected_outp ), MockConfig(source="configuration file", username=None, org=None, activation_key=None, password=None), ], - "You have passed the RHSM username without an associated password. Please provide a password together" + "You have passed the RHSM username without an associated password. Provide a password together" " with the username.", ), # Config File - username without password @@ -265,7 +265,7 @@ def test_handle_config_conflicts(config_sources, expected_message, expected_outp ), MockConfig(source="configuration file", username="test", org=None, activation_key=None, password=None), ], - "You have passed the RHSM username without an associated password. Please provide a password together" + "You have passed the RHSM username without an associated password. Provide a password together" " with the username.", ), ( diff --git a/convert2rhel/unit_tests/utils/utils_test.py b/convert2rhel/unit_tests/utils/utils_test.py index 5addda1056..46ca84f5a2 100644 --- a/convert2rhel/unit_tests/utils/utils_test.py +++ b/convert2rhel/unit_tests/utils/utils_test.py @@ -1152,10 +1152,10 @@ def test_remove_epoch_from_yum_nevra_notation(pkg_nevra, nvra_without_epoch): ( ( "CONVERT2RHEL_SKIP_KERNEL_CURRENCY_CHECK", - True, + "1", "skip_kernel_currency_check", - "The environment variable CONVERT2RHEL_SKIP_KERNEL_CURRENCY_CHECK is deprecated and is set to be removed on Convert2RHEL 2.4.0.\n" - "Please, use the configuration file instead.", + "The environment variable CONVERT2RHEL_SKIP_KERNEL_CURRENCY_CHECK is deprecated and will be removed in convert2rhel 2.4.0.\n" + "Use the skip_kernel_currency_check option in the /etc/convert2rhel.ini configuration file.", ), ), ) diff --git a/convert2rhel/utils/__init__.py b/convert2rhel/utils/__init__.py index 6d23a3fef0..f5f7c7ac5c 100644 --- a/convert2rhel/utils/__init__.py +++ b/convert2rhel/utils/__init__.py @@ -261,12 +261,12 @@ def inner_wrapper(*args, **kwargs): # API) will keep executing until they finish their execution and # ignore the call for termination issued by the parent. To avoid # having "zombie" processes, we need to wait for them to finish. - logger.warning("Terminating child process...") + logger.warning("Terminating child process.") if process.is_alive(): - logger.debug("Process with pid %s is alive", process.pid) + logger.debug("Process with pid %s is alive.", process.pid) process.terminate() - logger.debug("Process with pid %s exited", process.pid) + logger.debug("Process with pid %s exited.", process.pid) # If there is a KeyboardInterrupt raised while the child process is # being executed, let's just re-raise it to the stack and move on. @@ -511,7 +511,7 @@ def ask_to_continue(): if cont == "y": break if cont == "n": - logger.critical("User canceled the conversion\n") + logger.critical("User canceled the conversion.\n") def prompt_user(question, password=False): @@ -556,11 +556,11 @@ def remove_tmp_dir(): """Remove temporary folder (TMP_DIR), not needed post-conversion.""" try: shutil.rmtree(TMP_DIR) - logger.info("Temporary folder {} removed".format(TMP_DIR)) + logger.info("Temporary folder {} removed.".format(TMP_DIR)) except OSError as err: logger.warning("Failed removing temporary folder {}\nError ({}): {}".format(TMP_DIR, err.errno, err.strerror)) except TypeError: - logger.warning("TypeError error while removing temporary folder {}".format(TMP_DIR)) + logger.warning("TypeError error while removing temporary folder {}.".format(TMP_DIR)) class DictWListValues(dict): @@ -700,7 +700,7 @@ def remove_pkgs(pkgs_to_remove, critical=True): pkgs_removed = [] if not pkgs_to_remove: - logger.info("No package to remove") + logger.info("No package to remove.") return pkgs_removed pkgs_failed_to_remove = [] @@ -722,7 +722,7 @@ def remove_pkgs(pkgs_to_remove, critical=True): logger.critical_no_exit("Error: Couldn't remove {}.".format(pkgs_as_str)) raise exceptions.CriticalError( id_="FAILED_TO_REMOVE_PACKAGES", - title="Couldn't remove packages.", + title="Couldn't remove packages", description="While attempting to roll back changes, we encountered an unexpected failure while attempting to remove one or more of the packages we installed earlier.", diagnosis="Couldn't remove {}.".format(pkgs_as_str), ) @@ -1143,8 +1143,10 @@ def warn_deprecated_env(env_name): return None root_logger.warning( - "The environment variable {} is deprecated and is set to be removed on Convert2RHEL 2.4.0.\n" - "Please, use the configuration file instead.".format(env_name) + "The environment variable {} is deprecated and will be removed in convert2rhel 2.4.0.\n" + "Use the {} option in the /etc/convert2rhel.ini configuration file.".format( + env_name, env_var_to_toolopts_map[env_name] + ) ) key = env_var_to_toolopts_map[env_name] value = os.getenv(env_name, None) diff --git a/convert2rhel/utils/subscription.py b/convert2rhel/utils/subscription.py index d255b21021..d52aad177a 100644 --- a/convert2rhel/utils/subscription.py +++ b/convert2rhel/utils/subscription.py @@ -59,7 +59,7 @@ def setup_rhsm_parts(opts): # security practice. loggerinst.critical( "Failed to parse a valid subscription-manager server from the --serverurl option.\n" - "Please check for typos and run convert2rhel again with a corrected --serverurl.\n" + "Check for typos and run convert2rhel again with a corrected --serverurl.\n" "Supplied serverurl: {}\nError: {}".format(opts.serverurl, e) ) diff --git a/tests/integration/tier0/non-destructive/basic-sanity-checks/test_basic_sanity_checks.py b/tests/integration/tier0/non-destructive/basic-sanity-checks/test_basic_sanity_checks.py index 812d60b760..7a05e9eb79 100644 --- a/tests/integration/tier0/non-destructive/basic-sanity-checks/test_basic_sanity_checks.py +++ b/tests/integration/tier0/non-destructive/basic-sanity-checks/test_basic_sanity_checks.py @@ -213,7 +213,7 @@ def test_rhsm_error_logged(convert2rhel): # Wait until we reach the point where the RHEL certificate has been # installed otherwise we won't attempt to remove it. - assert c2r.expect("PRE_SUBSCRIPTION has succeeded") == 0 + assert c2r.expect("The PRE_SUBSCRIPTION action has succeeded.") == 0 # Remove the certificate ourselves for potential_cert in ("74.pem", "69.pem", "479.pem"): diff --git a/tests/integration/tier0/non-destructive/config-file/test_config_file.py b/tests/integration/tier0/non-destructive/config-file/test_config_file.py index af0022a322..2f9a000691 100644 --- a/tests/integration/tier0/non-destructive/config-file/test_config_file.py +++ b/tests/integration/tier0/non-destructive/config-file/test_config_file.py @@ -174,7 +174,7 @@ def test_config_standard_paths_priority_diff_methods(convert2rhel, c2r_config_se "WARNING - Either a password or an activation key can be used for system registration." " We're going to use the activation key." ) - c2r.expect("SUBSCRIBE_SYSTEM has succeeded") + c2r.expect("The SUBSCRIBE_SYSTEM action has succeeded.") assert c2r.exitstatus == 0 @@ -211,6 +211,6 @@ def test_config_standard_paths_priority(convert2rhel, c2r_config_setup): with convert2rhel(f"analyze --serverurl {TEST_VARS['RHSM_SERVER_URL']} -y --debug") as c2r: c2r.expect("DEBUG - Found username in subscription_manager") c2r.expect("DEBUG - Found password in subscription_manager") - c2r.expect("SUBSCRIBE_SYSTEM has succeeded") + c2r.expect("The SUBSCRIBE_SYSTEM action has succeeded.") assert c2r.exitstatus == 0 diff --git a/tests/integration/tier0/non-destructive/cve-2022-1662/test_cve-2022-1662.py b/tests/integration/tier0/non-destructive/cve-2022-1662/test_cve-2022-1662.py index 70fbfa4091..d6f4e31b59 100644 --- a/tests/integration/tier0/non-destructive/cve-2022-1662/test_cve-2022-1662.py +++ b/tests/integration/tier0/non-destructive/cve-2022-1662/test_cve-2022-1662.py @@ -30,7 +30,7 @@ def test_passing_password_to_submgr_obfuscated(convert2rhel): # Just to be sure, try to run through all three tries # of the registration process in case the race condition applies for subscription_try in range(2): - c2r.expect("Registering the system using subscription-manager ...") + c2r.expect("Registering the system using subscription-manager.") # Run watchdog function using multiprocessing pool # as soon as Convert2RHEL tries to call subscription-manager with Pool(processes=1) as pool: @@ -52,7 +52,7 @@ def test_passing_activation_key_to_submgr_obfuscated(convert2rhel): # Just to be sure, try to run through all three tries # of the registration process in case the race condition applies for subscription_try in range(2): - c2r.expect("Registering the system using subscription-manager ...") + c2r.expect("Registering the system using subscription-manager.") # Run watchdog function using multiprocessing pool # as soon as Convert2RHEL tries to call subscription-manager with Pool(processes=1) as pool: diff --git a/tests/integration/tier0/non-destructive/enabled-repositories-after-analysis/test_enabled_repositories_after_analysis.py b/tests/integration/tier0/non-destructive/enabled-repositories-after-analysis/test_enabled_repositories_after_analysis.py index 6a49a5c1ef..10e25690c7 100644 --- a/tests/integration/tier0/non-destructive/enabled-repositories-after-analysis/test_enabled_repositories_after_analysis.py +++ b/tests/integration/tier0/non-destructive/enabled-repositories-after-analysis/test_enabled_repositories_after_analysis.py @@ -48,7 +48,7 @@ def test_enabled_repositories_after_analysis( with convert2rhel("analyze -y --debug") as c2r: c2r.expect("Enabling RHEL repositories:") c2r.expect("rhel-7-server-rpms") - c2r.expect("Rollback: Restoring state of the repositories") + c2r.expect("Rollback: Restore state of the repositories") assert c2r.exitstatus == 0 diff --git a/tests/integration/tier0/non-destructive/grub/test_invalid_changed_to_grub.py b/tests/integration/tier0/non-destructive/grub/test_invalid_changed_to_grub.py index c0d30f57af..c6c6d576cb 100644 --- a/tests/integration/tier0/non-destructive/grub/test_invalid_changed_to_grub.py +++ b/tests/integration/tier0/non-destructive/grub/test_invalid_changed_to_grub.py @@ -51,9 +51,7 @@ def test_invalid_changes_to_grub_file(convert2rhel, grub_file_invalid): TEST_VARS["RHSM_SCA_PASSWORD"], ) ) as c2r: - assert c2r.expect_exact("Prepare: Check if the grub file is valid") == 0 - assert ( - c2r.expect_exact("ERROR - (ERROR) GRUB_VALIDITY::INVALID_GRUB_FILE - Grub boot entry file is invalid") == 0 - ) + assert c2r.expect_exact("Prepare: Check validity of /etc/default/grub") == 0 + assert c2r.expect_exact("ERROR - (ERROR) GRUB_VALIDITY::INVALID_GRUB_FILE - /etc/default/grub invalid") == 0 assert c2r.exitstatus == 2 diff --git a/tests/integration/tier0/non-destructive/kernel/test_kernel_check_verification.py b/tests/integration/tier0/non-destructive/kernel/test_kernel_check_verification.py index 65cfca62af..5a16ed437a 100644 --- a/tests/integration/tier0/non-destructive/kernel/test_kernel_check_verification.py +++ b/tests/integration/tier0/non-destructive/kernel/test_kernel_check_verification.py @@ -44,7 +44,8 @@ def test_verify_latest_kernel_check_passes_with_failed_repoquery(convert2rhel, t c2r.sendline("y") c2r.expect( - "Couldn't fetch the list of the most recent kernels available in the repositories. Did not perform the loaded kernel check.", + "Couldn't fetch the list of the most recent kernels available in the repositories. Did not perform the" + " loaded kernel currency check.", timeout=300, ) c2r.sendcontrol("c") diff --git a/tests/integration/tier0/non-destructive/single-yum-transaction-validation/test_single_yum_transaction_validation.py b/tests/integration/tier0/non-destructive/single-yum-transaction-validation/test_single_yum_transaction_validation.py index cd4d43801f..8c2509e916 100644 --- a/tests/integration/tier0/non-destructive/single-yum-transaction-validation/test_single_yum_transaction_validation.py +++ b/tests/integration/tier0/non-destructive/single-yum-transaction-validation/test_single_yum_transaction_validation.py @@ -80,7 +80,7 @@ def test_package_download_error(convert2rhel, shell, yum_cache): TEST_VARS["RHSM_SCA_PASSWORD"], ) ) as c2r: - c2r.expect("Validate the {} transaction".format(PKGMANAGER)) + c2r.expect("Validate the main {} transaction".format(PKGMANAGER)) c2r.expect("Adding {} packages to the {} transaction set.".format(SERVER_SUB, PKGMANAGER)) if re.match(r"^(centos|oracle)-7$", SYSTEM_RELEASE_ENV): @@ -129,7 +129,7 @@ def test_transaction_validation_error(convert2rhel, shell, yum_cache): os.unlink("/var/cache/yum/x86_64/7Server/rhel-7-server-rpms/repomd.xml") remove_entitlement_certs() - c2r.expect("Failed to validate the yum transaction.", timeout=600) + c2r.expect("Failed to validate a yum transaction.", timeout=600) # Error header first c2r.expect("Pre-conversion analysis report", timeout=600) @@ -195,7 +195,7 @@ def test_packages_with_in_name_period(shell, convert2rhel, packages_with_period) c2r.expect("Continue with the system conversion", timeout=300) c2r.sendline("y") - c2r.expect("VALIDATE_PACKAGE_MANAGER_TRANSACTION has succeeded") + c2r.expect("The VALIDATE_PACKAGE_MANAGER_TRANSACTION action has succeeded.") assert c2r.exitstatus == 0 @@ -228,7 +228,7 @@ def test_override_exclude_list_in_yum_config(convert2rhel, outdated_kernel, yum_ TEST_VARS["RHSM_SCA_PASSWORD"], ) ) as c2r: - c2r.expect("VALIDATE_PACKAGE_MANAGER_TRANSACTION has succeeded") + c2r.expect("The VALIDATE_PACKAGE_MANAGER_TRANSACTION action has succeeded.") assert c2r.exitstatus == 0 except (AssertionError, pexpect.exceptions.EOF, pexpect.exceptions.TIMEOUT) as e: diff --git a/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_pre_register.py b/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_pre_register.py index 31dec25c06..4189070d83 100644 --- a/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_pre_register.py +++ b/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_pre_register.py @@ -23,7 +23,7 @@ def test_pre_registered_wont_unregister(shell, pre_registered, convert2rhel): c2r.expect("Subscription Manager is already present", timeout=300) c2r.expect( - "SUBSCRIBE_SYSTEM has succeeded", + "The SUBSCRIBE_SYSTEM action has succeeded.", timeout=600, ) c2r.expect("Continue with the system conversion?") @@ -99,7 +99,7 @@ def test_no_sca_not_subscribed(shell, pre_registered, convert2rhel): c2r.sendline("y") c2r.expect("We'll try to auto-attach a subscription") - c2r.expect("SUBSCRIBE_SYSTEM has succeeded") + c2r.expect("The SUBSCRIBE_SYSTEM action has succeeded.") c2r.expect("Continue with the system conversion?") c2r.sendline("n") diff --git a/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_rollback.py b/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_rollback.py index 79a60e4b4f..bb089ab0f7 100644 --- a/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_rollback.py +++ b/tests/integration/tier0/non-destructive/subscription-manager/test_sub_man_rollback.py @@ -25,7 +25,7 @@ def test_sub_man_rollback(convert2rhel, shell, fixture_subman): TEST_VARS["RHSM_SCA_PASSWORD"], ) ) as c2r: - assert c2r.expect("Validate the dnf transaction") == 0 + assert c2r.expect("Validate the main dnf transaction") == 0 # At this point the centos-linux-release package is already installed c2r.sendcontrol("c") # Expect rollback, otherwise TIMEOUT diff --git a/tests/integration/tier1/destructive/yum-conf-exclude-packages/test_yum_conf_exclude_packages.py b/tests/integration/tier1/destructive/yum-conf-exclude-packages/test_yum_conf_exclude_packages.py index a9098c2648..652f34ec5a 100644 --- a/tests/integration/tier1/destructive/yum-conf-exclude-packages/test_yum_conf_exclude_packages.py +++ b/tests/integration/tier1/destructive/yum-conf-exclude-packages/test_yum_conf_exclude_packages.py @@ -19,6 +19,6 @@ def test_yum_conf_exclude_packages(convert2rhel, yum_conf_exclude): TEST_VARS["RHSM_SCA_PASSWORD"], ) ) as c2r: - c2r.expect("IS_LOADED_KERNEL_LATEST has succeeded") + c2r.expect("The IS_LOADED_KERNEL_LATEST action has succeeded.") assert c2r.exitstatus == 0 diff --git a/tests/integration/tier1/non-destructive/httpd-package-transaction-error/test_httpd_package_transaction_error.py b/tests/integration/tier1/non-destructive/httpd-package-transaction-error/test_httpd_package_transaction_error.py index 210e49a5ed..03dbee9aa8 100644 --- a/tests/integration/tier1/non-destructive/httpd-package-transaction-error/test_httpd_package_transaction_error.py +++ b/tests/integration/tier1/non-destructive/httpd-package-transaction-error/test_httpd_package_transaction_error.py @@ -74,7 +74,7 @@ def test_httpd_package_transaction_error(shell, convert2rhel, handle_packages): timeout=900, ) assert index == 0, "The analysis found an error. Probably related to the transaction check." - assert c2r.expect_exact("VALIDATE_PACKAGE_MANAGER_TRANSACTION has succeeded") == 0 + assert c2r.expect_exact("The VALIDATE_PACKAGE_MANAGER_TRANSACTION action has succeeded.") == 0 # Correct handling of the httpd package dependencies is expected assert c2r.exitstatus == 0