Blame SOURCES/BZ-1399628-updateinfo-fix-wrong-pkg-count.patch

5e9bef
commit 9474b6a7be57cd1c83da4a5db3fc0f48c61f6056
5e9bef
Author: Valentina Mukhamedzhanova <vmukhame@redhat.com>
5e9bef
Date:   Wed Oct 26 13:42:04 2016 +0200
5e9bef
5e9bef
    Filter duplicate packages from different repos in doPackageLists(pkgnarrow='obsoletes').
5e9bef
5e9bef
diff --git a/yum/__init__.py b/yum/__init__.py
5e9bef
index 9e38320..9780d96 100644
5e9bef
--- a/yum/__init__.py
5e9bef
+++ b/yum/__init__.py
5e9bef
@@ -3109,9 +3109,13 @@ much more problems).
5e9bef
                 pkgs = self.pkgSack.searchNevra(name=n, arch=a, ver=v, rel=r, epoch=e)
5e9bef
                 pkgs = misc.filter_pkgs_repoid(pkgs, repoid)
5e9bef
                 instpo = self.getInstalledPackageObject(instTup)
5e9bef
-                for po in pkgs:
5e9bef
-                    obsoletes.append(po)
5e9bef
-                    obsoletesTuples.append((po, instpo))
5e9bef
+                if len(pkgs) > 1:
5e9bef
+                    self.verbose_logger.log(logginglevels.DEBUG_1,
5e9bef
+                        _('More than one identical match in sack for %s'),
5e9bef
+                        pkgs[0])
5e9bef
+                if len(pkgs) >= 1:
5e9bef
+                    obsoletes.append(pkgs[0])
5e9bef
+                    obsoletesTuples.append((pkgs[0], instpo))
5e9bef
             if patterns:
5e9bef
                 exactmatch, matched, unmatched = \
5e9bef
                    parsePackages(obsoletes, patterns, casematch=not ignore_case)
5e9bef
5e9bef
commit 400e248d3334d54fcf98d106d1cd84acae2e6e15
5e9bef
Author: Valentina Mukhamedzhanova <vmukhame@redhat.com>
5e9bef
Date:   Mon Oct 31 10:28:04 2016 +0100
5e9bef
5e9bef
    Filter duplicates when counting security updates.
5e9bef
5e9bef
diff --git a/yum/updateinfo.py b/yum/updateinfo.py
5e9bef
index 5dcd7df..35e4c0f 100644
5e9bef
--- a/yum/updateinfo.py
5e9bef
+++ b/yum/updateinfo.py
5e9bef
@@ -456,8 +456,8 @@ def exclude_updates(base, filters=None):
5e9bef
         for p in base.doPackageLists(pkgnarrow='available', patterns=pkgs_to_del, showdups=True).available:
5e9bef
             ysp_del_pkg(p)
5e9bef
 
5e9bef
-    cnt = len(base.doPackageLists(pkgnarrow='updates').updates) + \
5e9bef
-          len(base.doPackageLists(pkgnarrow='obsoletes').obsoletes)
5e9bef
+    cnt = len(set(base.doPackageLists(pkgnarrow='updates').updates + \
5e9bef
+                  base.doPackageLists(pkgnarrow='obsoletes').obsoletes))
5e9bef
 
5e9bef
     _ysp_chk_used_map(used_map, lambda x: base.verbose_logger.warn("%s", x))
5e9bef
 
5e9bef
5e9bef
commit 02753215c8e28dbc75aacff678c33343d0539b33
5e9bef
Author: Michal Domonkos <mdomonko@redhat.com>
5e9bef
Date:   Wed Feb 15 16:51:57 2017 +0100
5e9bef
5e9bef
    updateinfo: filter pkg dupes from total count. BZ 1399628
5e9bef
    
5e9bef
    This complements commit 400e248.
5e9bef
5e9bef
diff --git a/yum/updateinfo.py b/yum/updateinfo.py
5e9bef
index 35e4c0f..b6a42ea 100644
5e9bef
--- a/yum/updateinfo.py
5e9bef
+++ b/yum/updateinfo.py
5e9bef
@@ -436,11 +436,8 @@ def exclude_updates(base, filters=None):
5e9bef
 
5e9bef
     used_map = _ysp_gen_used_map(opts)
5e9bef
 
5e9bef
-    upds = base.doPackageLists(pkgnarrow='updates')
5e9bef
-    tot = len(upds.updates)
5e9bef
-    # In theory we don't need to do this in some cases, but meh.
5e9bef
-    upds = base.doPackageLists(pkgnarrow='obsoletes')
5e9bef
-    tot += len(upds.obsoletes)
5e9bef
+    tot = len(set(base.doPackageLists(pkgnarrow='updates').updates + \
5e9bef
+                  base.doPackageLists(pkgnarrow='obsoletes').obsoletes))
5e9bef
 
5e9bef
     pkgs = base.pkgSack.returnPackages()
5e9bef
     name2tup = _get_name2oldpkgtup(base)