From f3a04ac8a0323d812f628e39206eae676b5cdc47 Mon Sep 17 00:00:00 2001 From: Tzu-ping Chung Date: Mon, 10 Aug 2020 02:22:12 +0800 Subject: [PATCH] Add block to catch connection and proxy errors This allows us to output a more specific error message to help users in common cases. --- docs/html/user_guide.rst | 5 ++++- src/pip/_internal/index/collector.py | 12 +++++++++++- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/docs/html/user_guide.rst b/docs/html/user_guide.rst index 73a2643223b..24291181cee 100644 --- a/docs/html/user_guide.rst +++ b/docs/html/user_guide.rst @@ -788,7 +788,10 @@ archives are built with identical packages. to use such a package, see :ref:`Controlling setup_requires`. -.. _`Using pip from your program`: +Fixing network errors +===================== + +TODO Fixing conflicting dependencies =============================== diff --git a/src/pip/_internal/index/collector.py b/src/pip/_internal/index/collector.py index b86f62f4624..013d5a07b5f 100644 --- a/src/pip/_internal/index/collector.py +++ b/src/pip/_internal/index/collector.py @@ -13,7 +13,7 @@ from pip._vendor import html5lib, requests from pip._vendor.distlib.compat import unescape -from pip._vendor.requests.exceptions import RetryError, SSLError +from pip._vendor.requests.exceptions import ProxyError, RetryError, SSLError from pip._vendor.six.moves.urllib import parse as urllib_parse from pip._vendor.six.moves.urllib import request as urllib_request @@ -460,6 +460,16 @@ def _get_html_page(link, session=None): except SSLError as exc: reason = "There was a problem confirming the ssl certificate" logger.warning("Could not fetch URL %s: %s: %s", link, reason, exc) + except (requests.ConnectTimeout, ProxyError): + template = ( + "Skipping URL %s since the connection timed out. This is likely " + "caused by a misconfigured network or proxy." + ) + logger.warning(template, link) + logger.warning( + "For help, visit " + "https://pip.pypa.io/en/latest/user_guide/#fixing-network-errors" + ) except requests.ConnectionError as exc: reason = "connection error" logger.warning("Could not fetch URL %s: %s: %s", link, reason, exc)