Commit 621d7fd5 authored by Berker Peksag's avatar Berker Peksag

Issue #6500: Fix "maximum recursion depth exceeded" error caused by Request.__getattr__()

parent 0f3a71da
......@@ -1302,6 +1302,13 @@ class RequestTests(unittest.TestCase):
self.assertEqual("POST", self.post.get_method())
self.assertEqual("GET", self.get.get_method())
def test___getattr__(self):
self.assertEqual("GET", self.get._Request__r_method)
self.assertEqual("http://www.python.org/~jeremy/",
self.get._Request__r_full_url)
with self.assertRaises(AttributeError):
self.get._Request__r_invalid_attr
def test_add_data(self):
self.assertTrue(not self.get.has_data())
self.assertEqual("GET", self.get.get_method())
......
......@@ -251,8 +251,7 @@ class Request:
if attr[:12] == '_Request__r_':
name = attr[12:]
if hasattr(Request, 'get_' + name):
getattr(self, 'get_' + name)()
return getattr(self, attr)
return getattr(self, 'get_' + name)()
raise AttributeError, attr
def get_method(self):
......
......@@ -36,6 +36,9 @@ Core and Builtins
Library
-------
- Issue #6500: Fix "maximum recursion depth exceeded" error caused
by urllib2.Request.__getattr__().
- Issue #24103: Fixed possible use after free in ElementTree.iterparse().
- Issue #20954: _args_from_interpreter_flags used by multiprocessing and some
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment