From 82b0fd01aaf851c5a632c2a887d860d1e2e33920 Mon Sep 17 00:00:00 2001 From: Moritz Kiemer Date: Thu, 16 Jan 2025 10:52:42 +0100 Subject: [PATCH] update config: Manifest is not hashable Change-Id: I4899e5eb34d5326cfd10990945d96f0cfcae92a7 --- .../pre_actions/agent_based_plugins.py | 22 +++++++++---------- 1 file changed, 11 insertions(+), 11 deletions(-) diff --git a/cmk/update_config/plugins/pre_actions/agent_based_plugins.py b/cmk/update_config/plugins/pre_actions/agent_based_plugins.py index e1efdbc7518..42cbf20fbe4 100644 --- a/cmk/update_config/plugins/pre_actions/agent_based_plugins.py +++ b/cmk/update_config/plugins/pre_actions/agent_based_plugins.py @@ -12,7 +12,7 @@ from cmk.gui.exceptions import MKUserError from cmk.gui.utils.urls import werk_reference_url, WerkReference -from cmk.mkp_tool import Manifest +from cmk.mkp_tool import Manifest, PackageID from cmk.update_config.plugins.pre_actions.utils import ( AGENT_BASED_PLUGINS_PREACTION_SORT_INDEX, ConflictMode, @@ -43,11 +43,13 @@ def __call__(self, logger: Logger, conflict_mode: ConflictMode) -> None: return installer, package_map = get_installer_and_package_map(path_config) # group the local_agent_based_plugins_dir files by package - grouped_files: dict[Manifest, list[Path]] = {} + grouped_files: dict[PackageID, list[Path]] = {} + manifests: dict[PackageID, Manifest] = {} inactive_files_not_in_package = [] for path in self._get_files(): if (manifest := package_map.get(path.resolve())) is not None: - grouped_files.setdefault(manifest, []).append(path) + grouped_files.setdefault(manifest.id, []).append(path) + manifests[manifest.id] = manifest else: inactive_files_not_in_package.append(path) @@ -60,22 +62,20 @@ def __call__(self, logger: Logger, conflict_mode: ConflictMode) -> None: if _continue_per_users_choice(conflict_mode).is_abort(): raise MKUserError(None, "decommissioned file(s)") - for manifest, paths in grouped_files.items(): - if not is_applicable_mkp(manifest): + for package_id, paths in grouped_files.items(): + if not is_applicable_mkp(manifests[package_id]): logger.info( "[%s %s]: Ignoring problems (MKP will be disabled on target version)", - manifest.name, - manifest.version, + package_id.name, + package_id.version, ) continue _log_error_message_obsolete_files(logger, paths) logger.error( - f"The above file(s) are part of the extension package {manifest.name} {manifest.version}." + f"The above file(s) are part of the extension package {package_id.name} {package_id.version}." ) - if disable_incomp_mkp( - conflict_mode, manifest.id, installer, PACKAGE_STORE, path_config - ): + if disable_incomp_mkp(conflict_mode, package_id, installer, PACKAGE_STORE, path_config): continue raise MKUserError(None, "incompatible extension package")