summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJason R. Coombs <jaraco@jaraco.com>2011-12-03 14:39:58 (GMT)
committerJason R. Coombs <jaraco@jaraco.com>2011-12-03 14:39:58 (GMT)
commit0612e8c2a25909788a8df7482670fd473e0f51ba (patch)
tree869a0361c87930be698091e9bddcbb0f78936341
parentc9b644eac28614ae74afb52432ad71d7077e8add (diff)
parentaa204dbe9c83302781f7b9d7df6db225b3661f9e (diff)
downloadcpython-0612e8c2a25909788a8df7482670fd473e0f51ba.zip
cpython-0612e8c2a25909788a8df7482670fd473e0f51ba.tar.gz
cpython-0612e8c2a25909788a8df7482670fd473e0f51ba.tar.bz2
Merged fix for #13211 from 3.2
-rw-r--r--Lib/test/test_urllib2.py11
-rw-r--r--Lib/urllib/error.py6
2 files changed, 17 insertions, 0 deletions
diff --git a/Lib/test/test_urllib2.py b/Lib/test/test_urllib2.py
index aa1854d..cf6ccbc 100644
--- a/Lib/test/test_urllib2.py
+++ b/Lib/test/test_urllib2.py
@@ -1449,6 +1449,17 @@ class RequestTests(unittest.TestCase):
req = Request(url)
self.assertEqual(req.get_full_url(), url)
+def test_HTTPError_interface():
+ """
+ Issue 13211 reveals that HTTPError didn't implement the URLError
+ interface even though HTTPError is a subclass of URLError.
+
+ >>> err = urllib.error.HTTPError(msg='something bad happened', url=None, code=None, hdrs=None, fp=None)
+ >>> assert hasattr(err, 'reason')
+ >>> err.reason
+ 'something bad happened'
+ """
+
def test_main(verbose=None):
from test import test_urllib2
support.run_doctest(test_urllib2, verbose)
diff --git a/Lib/urllib/error.py b/Lib/urllib/error.py
index d05f850..c1dfc40 100644
--- a/Lib/urllib/error.py
+++ b/Lib/urllib/error.py
@@ -55,6 +55,12 @@ class HTTPError(URLError, urllib.response.addinfourl):
def __str__(self):
return 'HTTP Error %s: %s' % (self.code, self.msg)
+ # since URLError specifies a .reason attribute, HTTPError should also
+ # provide this attribute. See issue13211 for discussion.
+ @property
+ def reason(self):
+ return self.msg
+
# exception raised when downloaded size does not match content-length
class ContentTooShortError(URLError):
def __init__(self, message, content):