From c2c567344c526343d21473db9790778b45d9e614 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) - unique report message ids - fix typos - add missing context where messages are too short and vague - make TASK tense consistent --- convert2rhel/actions/__init__.py | 6 +- .../conversion/list_non_red_hat_pkgs_left.py | 2 +- .../conversion/preserve_only_rhel_kernel.py | 10 +- .../actions/conversion/set_efi_config.py | 2 +- .../actions/post_conversion/hostmetering.py | 39 ++++--- .../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 | 17 +-- .../pre_ponr_changes/kernel_modules.py | 4 +- .../actions/pre_ponr_changes/subscription.py | 12 +- .../check_firewalld_availability.py | 6 +- .../system_checks/convert2rhel_latest.py | 18 +-- 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 | 1 + convert2rhel/actions/system_checks/eus.py | 1 + .../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 | 28 ++--- 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 | 4 +- .../pkgmanager/handlers/dnf/__init__.py | 14 +-- .../pkgmanager/handlers/yum/__init__.py | 14 +-- convert2rhel/redhatrelease.py | 2 +- convert2rhel/repo.py | 2 +- convert2rhel/subscription.py | 34 +++--- convert2rhel/systeminfo.py | 2 +- convert2rhel/toolopts/__init__.py | 4 +- convert2rhel/toolopts/config.py | 6 +- .../post_conversion/hostmetering_test.py | 106 ++++++++---------- .../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 | 12 +- .../pre_ponr_changes/kernel_modules_test.py | 6 +- .../pre_ponr_changes/subscription_test.py | 2 +- .../check_firewalld_availability_test.py | 2 +- .../system_checks/convert2rhel_latest_test.py | 19 ++-- .../actions/system_checks/dbus_test.py | 6 +- .../actions/system_checks/efi_test.py | 2 +- .../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 | 2 +- .../pkgmanager/handlers/dnf/dnf_test.py | 10 +- .../pkgmanager/handlers/yum/yum_test.py | 8 +- 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 +- 68 files changed, 335 insertions(+), 336 deletions(-) diff --git a/convert2rhel/actions/__init__.py b/convert2rhel/actions/__init__.py index ad2c77ef8e..72fbaa6e54 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 e13b7688ba..9bcabc65b9 100644 --- a/convert2rhel/actions/conversion/preserve_only_rhel_kernel.py +++ b/convert2rhel/actions/conversion/preserve_only_rhel_kernel.py @@ -96,7 +96,7 @@ def run(self): for entry in boot_entries: # The boot loader 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, @@ -140,7 +140,7 @@ def run(self): """ super(FixDefaultKernel, self).run() - loggerinst.info("Checking for incorrect boot kernel") + loggerinst.info("Checking for incorrect boot kernel.") kernel_sys_cfg = utils.get_file_content("/etc/sysconfig/kernel") possible_kernels = ["kernel-uek", "kernel-plus"] @@ -162,7 +162,7 @@ def run(self): 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("Boot kernel {} was changed to {}.".format(kernel_to_change, new_kernel_str)) else: loggerinst.debug("Boot kernel validated.") @@ -186,7 +186,7 @@ def remove_non_rhel_kernels(self): loggerinst.info("None found.") return None - loggerinst.info("Removing non-RHEL kernels\n") + loggerinst.info("Removing 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) @@ -204,7 +204,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]) 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 f83e69fcd6..9290e657b9 100644 --- a/convert2rhel/actions/post_conversion/hostmetering.py +++ b/convert2rhel/actions/post_conversion/hostmetering.py @@ -56,9 +56,9 @@ def run(self): logger.info("Did not perform host metering configuration. Only supported for RHEL 7.") self.add_message( level="INFO", - id="CONFIGURE_HOST_METERING_SKIP", - title="Did not perform host metering configuration.", - description="Host metering is supportted only for RHEL 7.", + id="CONFIGURE_HOST_METERING_SKIP_ONLY_RHEL_7", + title="Did not perform host metering configuration", + description="Host metering is supported only for RHEL 7.", ) return False @@ -68,9 +68,9 @@ def run(self): logger.info("Did not perform host-metering configuration.") self.add_message( level="INFO", - id="CONFIGURE_HOST_METERING_SKIP", - title="Did not perform host metering configuration as not needed.", - description="Host metering is not needed on the system.", + id="CONFIGURE_HOST_METERING_SKIP_NOT_HYPERSCALER", + title="Did not perform host metering configuration", + description="Host metering is not needed on the system as it is not running on a hyperscaler.", ) return False @@ -81,8 +81,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 @@ -101,9 +101,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 ), @@ -121,7 +121,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" @@ -141,8 +141,8 @@ def _check_host_metering_configuration(self): logger.debug("Configuration of host metering has not been enabled. Skipping it.") self.add_message( level="INFO", - id="CONFIGURE_HOST_METERING_SKIP", - title="Did not perform host metering configuration.", + id="CONFIGURE_HOST_METERING_SKIP_OPTION_NOT_DETECTED", + title="Did not perform host metering configuration", description="Configuration of host metering has been skipped.", diagnosis="We haven't detected 'configure_host_metering' in the convert2rhel.ini config file nor" " the CONVERT2RHEL_CONFIGURE_HOST_METERING environment variable.", @@ -172,19 +172,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..a63acbee35 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, ) @@ -170,7 +171,7 @@ def run(self): logger.info(message) self.add_message( level="INFO", - id="SPECIAL_PACKAGES_REMOVED", + id="SPECIAL_PACKAGES_TO_REMOVE", title="Special packages to be removed", description=( "We have identified installed packages that match a pre-defined list of packages that are" @@ -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/system_checks/check_firewalld_availability.py b/convert2rhel/actions/system_checks/check_firewalld_availability.py index 34dc7b44bd..3dc76c0cff 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 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 5fea4275a2..15cce54329 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: @@ -201,9 +201,9 @@ def run(self): ) self.add_message( level="WARNING", - id="OUTDATED_CONVERT2RHEL_VERSION", + id="OUTDATED_CONVERT2RHEL_VERSION_RHEL_6", 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" "We encourage you to update to the latest version.".format( @@ -215,9 +215,9 @@ def run(self): else: self.set_result( level="OVERRIDABLE", - id="OUT_OF_DATE", + id="OUTDATED_CONVERT2RHEL_VERSION", 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..20968336ae 100644 --- a/convert2rhel/actions/system_checks/els.py +++ b/convert2rhel/actions/system_checks/els.py @@ -33,6 +33,7 @@ def run(self): """Warn the user 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 diff --git a/convert2rhel/actions/system_checks/eus.py b/convert2rhel/actions/system_checks/eus.py index e40e6635ff..3e59da22c1 100644 --- a/convert2rhel/actions/system_checks/eus.py +++ b/convert2rhel/actions/system_checks/eus.py @@ -33,6 +33,7 @@ def run(self): """Warn the user 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: 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..c59deec8ce 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,36 +66,36 @@ 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 ) ), ) return - self.add_message( - level="WARNING", - id="SKIP_TAINTED_KERNEL_MODULE_CHECK", - title="Skip tainted kernel module check", - diagnosis="You have set the option to skip the tainted kernel module check.", - description=( - "We will ignore results of the check that makes sure no tainted kernel modules are loaded.\n" - "Beware, this could leave your system in a broken state." - ), - ) self.add_message( 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 ) ), ) + self.add_message( + level="WARNING", + id="SKIP_TAINTED_KERNEL_MODULE_CHECK", + title="Skip tainted kernel module check", + diagnosis="You have set the option to skip the tainted kernel module check.", + description=( + "We will ignore results of the check that makes sure no tainted kernel modules are loaded.\n" + "Beware, this could leave your system in a broken state." + ), + ) return logger.info("No tainted kernel module is loaded.") 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..42e14e1ff4 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. @@ -703,7 +703,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..5a7d46e32a 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)), ) @@ -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.", + id_="FAILED_TO_VALIDATE_DNF_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..0a4073f8a1 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)), ) @@ -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.", + id_="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..f842c8902b 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, ) @@ -216,8 +216,8 @@ def register_system(): ) ) raise exceptions.CriticalError( - id_="FAILED_TO_SUBSCRIBE_SYSTEM", - title="Failed to subscribe system.", + id_="FAILED_TO_SUBSCRIBE_SYSTEM_ETC_OS_RELEASE", + 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/post_conversion/hostmetering_test.py b/convert2rhel/unit_tests/actions/post_conversion/hostmetering_test.py index 4d72410f03..bee7ca1cdc 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" @@ -194,16 +194,14 @@ def test_configure_host_metering( (None, 0), ("", ""), False, - set( - ( - actions.ActionMessage( - level="INFO", - id="CONFIGURE_HOST_METERING_SKIP", - title="Did not perform host metering configuration.", - description="Host metering is supportted only for RHEL 7.", - ), - ), - ), + { + actions.ActionMessage( + level="INFO", + id="CONFIGURE_HOST_METERING_SKIP_ONLY_RHEL_7", + title="Did not perform host metering configuration", + description="Host metering is supported only for RHEL 7.", + ) + }, actions.ActionResult(level="SUCCESS", id="SUCCESS"), ), ( @@ -218,9 +216,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"), @@ -252,16 +250,14 @@ def test_configure_host_metering( (None, 0), ("", ""), None, - set( - ( - actions.ActionMessage( - level="INFO", - id="CONFIGURE_HOST_METERING_SKIP", - title="Did not perform host metering configuration as not needed.", - description="Host metering is not needed on the system.", - ), - ), - ), + { + actions.ActionMessage( + level="INFO", + id="CONFIGURE_HOST_METERING_SKIP_NOT_HYPERSCALER", + title="Did not perform host metering configuration", + description="Host metering is not needed on the system as it is not running on a hyperscaler.", + ) + }, actions.ActionResult(level="SUCCESS", id="SUCCESS"), ), ( @@ -271,23 +267,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"), ), ( @@ -297,22 +291,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"), ), ( @@ -326,7 +318,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" @@ -384,8 +376,8 @@ def test_configure_host_metering_no_env_var(monkeypatch, hostmetering_instance, expected = { actions.ActionMessage( level="INFO", - id="CONFIGURE_HOST_METERING_SKIP", - title="Did not perform host metering configuration.", + id="CONFIGURE_HOST_METERING_SKIP_OPTION_NOT_DETECTED", + title="Did not perform host metering configuration", description="Configuration of host metering has been skipped.", diagnosis="We haven't detected 'configure_host_metering' in the convert2rhel.ini config file nor" " the CONVERT2RHEL_CONFIGURE_HOST_METERING environment variable.", 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..0415b4c754 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()] @@ -177,7 +177,7 @@ def test_run_all_removed(self, monkeypatch, remove_special_packages_instance): ( actions.ActionMessage( level="INFO", - id="SPECIAL_PACKAGES_REMOVED", + id="SPECIAL_PACKAGES_TO_REMOVE", title="Special packages to be removed", description="We have identified installed packages that match a pre-defined list of packages that are" " to be removed during the conversion", @@ -212,14 +212,14 @@ 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={}, ), actions.ActionMessage( level="INFO", - id="SPECIAL_PACKAGES_REMOVED", + id="SPECIAL_PACKAGES_TO_REMOVE", title="Special packages to be removed", description=( "We have identified installed packages that match a pre-defined list of packages that are" @@ -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..a0939eba12 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 @@ -299,7 +299,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 af6939898f..92eb7b1989 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() @@ -155,8 +155,9 @@ def test_convert2rhel_latest_outdated_version_inhibitor( unit_tests.assert_actions_result( convert2rhel_latest_action_instance, level="OVERRIDABLE", - id="OUT_OF_DATE", + id="OUTDATED_CONVERT2RHEL_VERSION", 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) @@ -243,9 +244,9 @@ def test_convert2rhel_latest_outdated_version_warning( expected = { actions.ActionMessage( level="WARNING", - id="OUTDATED_CONVERT2RHEL_VERSION", + id="OUTDATED_CONVERT2RHEL_VERSION_RHEL_6", 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" "We encourage you to update to the latest version.".format(running_version, latest_version) @@ -506,7 +507,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" @@ -576,9 +577,9 @@ def ttest_convert2rhel_latest_multiple_packages( unit_tests.assert_actions_result( convert2rhel_latest_action_instance, level="OVERRIDABLE", - id="OUT_OF_DATE", + id="OUTDATED_CONVERT2RHEL_VERSION", 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) @@ -762,9 +763,9 @@ def test_convert2rhel_latest_bad_nevra_to_parse_pkg_string( unit_tests.assert_actions_result( convert2rhel_latest_action_instance, level="OVERRIDABLE", - id="OUT_OF_DATE", + id="OUTDATED_CONVERT2RHEL_VERSION", 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/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..2a88e6cbc5 100644 --- a/convert2rhel/unit_tests/main_test.py +++ b/convert2rhel/unit_tests/main_test.py @@ -186,7 +186,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..c63bfe50b0 100644 --- a/convert2rhel/unit_tests/pkgmanager/handlers/dnf/dnf_test.py +++ b/convert2rhel/unit_tests/pkgmanager/handlers/dnf/dnf_test.py @@ -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_DNF_TRANSACTION" in execinfo._excinfo[1].id + 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..057f65da0c 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_YUM_TRANSACTION" in execinfo._excinfo[1].id + 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) )