Blame SOURCES/0013-repomanage-Use-modules-only-from-repo-they-are-handl.patch

9f4a6f
From e80f79b2f5e17a20065617c0b614b272dd53c57c Mon Sep 17 00:00:00 2001
9f4a6f
From: =?UTF-8?q?Ale=C5=A1=20Mat=C4=9Bj?= <amatej@redhat.com>
9f4a6f
Date: Thu, 26 May 2022 07:21:45 +0200
9f4a6f
Subject: [PATCH] repomanage: Use modules only from repo they are handling
9f4a6f
 (RhBug:2072441)
9f4a6f
9f4a6f
= changelog =
9f4a6f
msg: [repomanage] Modules are used only when they belong to target repo
9f4a6f
type: bugfix
9f4a6f
resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2072441
9f4a6f
---
9f4a6f
 plugins/repomanage.py | 13 +++++++++----
9f4a6f
 1 file changed, 9 insertions(+), 4 deletions(-)
9f4a6f
9f4a6f
diff --git a/plugins/repomanage.py b/plugins/repomanage.py
9f4a6f
index 989bd78..67a6fc7 100644
9f4a6f
--- a/plugins/repomanage.py
9f4a6f
+++ b/plugins/repomanage.py
9f4a6f
@@ -66,7 +66,8 @@ class RepoManageCommand(dnf.cli.Command):
9f4a6f
         keepnum = int(self.opts.keep) # the number of items to keep
9f4a6f
 
9f4a6f
         try:
9f4a6f
-            repo_conf = self.base.repos.add_new_repo("repomanage_repo", self.base.conf, baseurl=[self.opts.path])
9f4a6f
+            REPOMANAGE_REPOID = "repomanage_repo"
9f4a6f
+            repo_conf = self.base.repos.add_new_repo(REPOMANAGE_REPOID, self.base.conf, baseurl=[self.opts.path])
9f4a6f
             # Always expire the repo, otherwise repomanage could use cached metadata and give identical results
9f4a6f
             # for multiple runs even if the actual repo changed in the meantime
9f4a6f
             repo_conf._repo.expire()
9f4a6f
@@ -78,9 +79,13 @@ class RepoManageCommand(dnf.cli.Command):
9f4a6f
                 module_packages = self.base._moduleContainer.getModulePackages()
9f4a6f
 
9f4a6f
                 for module_package in module_packages:
9f4a6f
-                    all_modular_artifacts.update(module_package.getArtifacts())
9f4a6f
-                    module_dict.setdefault(module_package.getNameStream(), {}).setdefault(
9f4a6f
-                        module_package.getVersionNum(), []).append(module_package)
9f4a6f
+                    # Even though we load only REPOMANAGE_REPOID other modules can be loaded from system
9f4a6f
+                    # failsafe data automatically, we don't want them affecting repomanage results so ONLY
9f4a6f
+                    # use modules from REPOMANAGE_REPOID.
9f4a6f
+                    if module_package.getRepoID() == REPOMANAGE_REPOID:
9f4a6f
+                        all_modular_artifacts.update(module_package.getArtifacts())
9f4a6f
+                        module_dict.setdefault(module_package.getNameStream(), {}).setdefault(
9f4a6f
+                            module_package.getVersionNum(), []).append(module_package)
9f4a6f
 
9f4a6f
         except dnf.exceptions.RepoError:
9f4a6f
             rpm_list = []
9f4a6f
-- 
9f4a6f
2.36.1
9f4a6f