Blame SOURCES/pip-nowarn-upgrade.patch

372d73
diff --git a/pip/utils/outdated.py b/pip/utils/outdated.py
372d73
index 2164cc3..c71539f 100644
372d73
--- a/pip/utils/outdated.py
372d73
+++ b/pip/utils/outdated.py
372d73
@@ -92,6 +92,21 @@ def load_selfcheck_statefile():
372d73
         return GlobalSelfCheckState()
372d73
 
372d73
 
372d73
+def pip_installed_by_pip():
372d73
+    """Checks whether pip was installed by pip
372d73
+
372d73
+    This is used not to display the upgrade message when pip is in fact
372d73
+    installed by system package manager, such as dnf on Fedora.
372d73
+    """
372d73
+    import pkg_resources
372d73
+    try:
372d73
+        dist = pkg_resources.get_distribution('pip')
372d73
+        return (dist.has_metadata('INSTALLER') and
372d73
+                'pip' in dist.get_metadata_lines('INSTALLER'))
372d73
+    except pkg_resources.DistributionNotFound:
372d73
+        return False
372d73
+
372d73
+
372d73
 def pip_version_check(session):
372d73
     """Check for an update for pip.
372d73
 
372d73
@@ -141,7 +156,8 @@ def pip_version_check(session):
372d73
 
372d73
         # Determine if our pypi_version is older
372d73
         if (pip_version < remote_version and
372d73
-                pip_version.base_version != remote_version.base_version):
372d73
+                pip_version.base_version != remote_version.base_version and
372d73
+                pip_installed_by_pip()):
372d73
             # Advise "python -m pip" on Windows to avoid issues
372d73
             # with overwriting pip.exe.
372d73
             if WINDOWS: