diff options
author | Berker Peksag <berker.peksag@gmail.com> | 2016-03-06 14:17:47 (GMT) |
---|---|---|
committer | Berker Peksag <berker.peksag@gmail.com> | 2016-03-06 14:17:47 (GMT) |
commit | 48238c7e373aed6bf0f246b6c0887827397ae5ce (patch) | |
tree | 1644dbb0d394672ce5b7e44b0cb30c82835114de | |
parent | 656e41ec67befb2377be0bae6e1e0fca31413f9c (diff) | |
parent | e88dd1c32c2961e0fe40b09c48904451fa1eba9a (diff) | |
download | cpython-48238c7e373aed6bf0f246b6c0887827397ae5ce.zip cpython-48238c7e373aed6bf0f246b6c0887827397ae5ce.tar.gz cpython-48238c7e373aed6bf0f246b6c0887827397ae5ce.tar.bz2 |
Issue #2202: Fix UnboundLocalError in AbstractDigestAuthHandler.get_algorithm_impls
Raise ValueError if algorithm is not MD5 or SHA.
Initial patch by Mathieu Dupuy.
-rw-r--r-- | Lib/test/test_urllib2.py | 12 | ||||
-rw-r--r-- | Lib/urllib/request.py | 3 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
3 files changed, 17 insertions, 1 deletions
diff --git a/Lib/test/test_urllib2.py b/Lib/test/test_urllib2.py index a5281d8..008c751 100644 --- a/Lib/test/test_urllib2.py +++ b/Lib/test/test_urllib2.py @@ -13,7 +13,8 @@ import urllib.request # proxy config data structure but is testable on all platforms. from urllib.request import (Request, OpenerDirector, HTTPBasicAuthHandler, HTTPPasswordMgrWithPriorAuth, _parse_proxy, - _proxy_bypass_macosx_sysconf) + _proxy_bypass_macosx_sysconf, + AbstractDigestAuthHandler) from urllib.parse import urlparse import urllib.error import http.client @@ -1680,6 +1681,15 @@ class MiscTests(unittest.TestCase): self.assertRaises(ValueError, _parse_proxy, 'file:/ftp.example.com'), + def test_unsupported_algorithm(self): + handler = AbstractDigestAuthHandler() + with self.assertRaises(ValueError) as exc: + handler.get_algorithm_impls('invalid') + self.assertEqual( + str(exc.exception), + "Unsupported digest authentication algorithm 'invalid'" + ) + class RequestTests(unittest.TestCase): class PutRequest(Request): diff --git a/Lib/urllib/request.py b/Lib/urllib/request.py index e3eed16..909c2cf 100644 --- a/Lib/urllib/request.py +++ b/Lib/urllib/request.py @@ -1171,6 +1171,9 @@ class AbstractDigestAuthHandler: elif algorithm == 'SHA': H = lambda x: hashlib.sha1(x.encode("ascii")).hexdigest() # XXX MD5-sess + else: + raise ValueError("Unsupported digest authentication " + "algorithm %r" % algorithm) KD = lambda s, d: H("%s:%s" % (s, d)) return H, KD @@ -201,6 +201,9 @@ Core and Builtins Library ------- +- Issue #2202: Fix UnboundLocalError in + AbstractDigestAuthHandler.get_algorithm_impls. Initial patch by Mathieu Dupuy. + - Issue #26167: Minimized overhead in copy.copy() and copy.deepcopy(). Optimized copying and deepcopying bytearrays, NotImplemented, slices, short lists, tuples, dicts, sets. |