Blame SOURCES/BZ-1186690-compare_providers_priorities.patch

5e9bef
commit 9fb7032802a0f56cc85cf301478b48b3c72449e7
5e9bef
Author: Valentina Mukhamedzhanova <vmukhame@redhat.com>
5e9bef
Date:   Tue May 10 16:42:01 2016 +0200
5e9bef
5e9bef
    Add compare_providers_priority repository option.
5e9bef
5e9bef
diff --git a/test/testbase.py b/test/testbase.py
5e9bef
index 467f8fb..73c97a1 100644
5e9bef
--- a/test/testbase.py
5e9bef
+++ b/test/testbase.py
5e9bef
@@ -89,6 +89,7 @@ class FakeRepo(object):
5e9bef
             sack = self.__fake_sack
5e9bef
         self.sack = sack
5e9bef
         self.cost = 1000
5e9bef
+        self.compare_providers_priority = 80
5e9bef
 
5e9bef
     def __cmp__(self, other):
5e9bef
         """ Sort base class repos. by alphanumeric on their id, also
5e9bef
diff --git a/yum/config.py b/yum/config.py
5e9bef
index cae914d..1ee6dd3 100644
5e9bef
--- a/yum/config.py
5e9bef
+++ b/yum/config.py
5e9bef
@@ -1032,6 +1032,8 @@ class RepoConf(BaseConfig):
5e9bef
 
5e9bef
     check_config_file_age = Inherit(YumConf.check_config_file_age)
5e9bef
 
5e9bef
+    compare_providers_priority = IntOption(80, range_min=1, range_max=99)
5e9bef
+
5e9bef
     
5e9bef
 class VersionGroupConf(BaseConfig):
5e9bef
     """Option definitions for version groups."""
5e9bef
diff --git a/yum/depsolve.py b/yum/depsolve.py
5e9bef
index b482115..3453456 100644
5e9bef
--- a/yum/depsolve.py
5e9bef
+++ b/yum/depsolve.py
5e9bef
@@ -1653,6 +1653,12 @@ class Depsolve(object):
5e9bef
                         pkgresults[po] += 5
5e9bef
 
5e9bef
             # End of O(N*N): for nextpo in pkgs:
5e9bef
+
5e9bef
+            # Respect the repository priority for each provider, the default is 80
5e9bef
+            pkgresults[po] += (100 - po.repo.compare_providers_priority) * 10
5e9bef
+            self.verbose_logger.log(logginglevels.DEBUG_4,
5e9bef
+                _('compare_providers_priority for %s is %s' % (po, po.repo.compare_providers_priority)))
5e9bef
+
5e9bef
             if _common_sourcerpm(po, reqpo):
5e9bef
                 self.verbose_logger.log(logginglevels.DEBUG_4,
5e9bef
                     _('common sourcerpm %s and %s' % (po, reqpo)))
5e9bef
diff -up yum-3.4.3/docs/yum.conf.5.old yum-3.4.3/docs/yum.conf.5
5e9bef
--- yum-3.4.3/docs/yum.conf.5.old	2016-05-10 17:00:13.406111903 +0200
5e9bef
+++ yum-3.4.3/docs/yum.conf.5	2016-05-10 17:01:03.302427161 +0200
5e9bef
@@ -1229,6 +1229,14 @@ parallel, if possible.  Defaults to True
5e9bef
 Overrides the \fBui_repoid_vars\fR option from the [main] section for this
5e9bef
 repository.
5e9bef
 
5e9bef
+.IP
5e9bef
+\fBcompare_providers_priority \fR
5e9bef
+During depsolving, when choosing the best provider among several, yum will respect
5e9bef
+the priority of each provider's repository (note that there are other factors
5e9bef
+which yum considers, which may overweigh the repository priority). The value is
5e9bef
+an integer from 1 to 99, 1 being the most preferred repository, and 99 being
5e9bef
+the least preferred one. By default all repositories have the priority of 80.
5e9bef
+
5e9bef
 .SH "URL INCLUDE SYNTAX"
5e9bef
 .LP
5e9bef
 The inclusion of external configuration files is supported for /etc/yum.conf