diff options
author | Benjamin Peterson <benjamin@python.org> | 2009-03-02 22:41:42 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2009-03-02 22:41:42 (GMT) |
commit | 7d49bba969a6ca490ade6aa908e350d3c05f76f4 (patch) | |
tree | f3c3dbd9573fda44d86f40f9c1b9ff9fa7707529 | |
parent | ce45a967c2d82a6b3112c5621993f5fec1dd5ea1 (diff) | |
download | cpython-7d49bba969a6ca490ade6aa908e350d3c05f76f4.zip cpython-7d49bba969a6ca490ade6aa908e350d3c05f76f4.tar.gz cpython-7d49bba969a6ca490ade6aa908e350d3c05f76f4.tar.bz2 |
give httplib.IncompleteRead a more sane repr #4308
-rw-r--r-- | Lib/httplib.py | 13 | ||||
-rw-r--r-- | Lib/test/test_httplib.py | 19 | ||||
-rw-r--r-- | Misc/ACKS | 1 | ||||
-rw-r--r-- | Misc/NEWS | 3 |
4 files changed, 34 insertions, 2 deletions
diff --git a/Lib/httplib.py b/Lib/httplib.py index 85e49ab..2e749ea 100644 --- a/Lib/httplib.py +++ b/Lib/httplib.py @@ -626,7 +626,7 @@ class HTTPResponse: while amt > 0: chunk = self.fp.read(min(amt, MAXAMOUNT)) if not chunk: - raise IncompleteRead(s) + raise IncompleteRead(''.join(s), amt) s.append(chunk) amt -= len(chunk) return ''.join(s) @@ -1161,9 +1161,18 @@ class UnimplementedFileMode(HTTPException): pass class IncompleteRead(HTTPException): - def __init__(self, partial): + def __init__(self, partial, expected=None): self.args = partial, self.partial = partial + self.expected = expected + def __repr__(self): + if self.expected is not None: + e = ', %i more expected' % self.expected + else: + e = '' + return 'IncompleteRead(%i bytes read%s)' % (len(self.partial), e) + def __str__(self): + return repr(self) class ImproperConnectionState(HTTPException): pass diff --git a/Lib/test/test_httplib.py b/Lib/test/test_httplib.py index c8c0648..54a2b0e 100644 --- a/Lib/test/test_httplib.py +++ b/Lib/test/test_httplib.py @@ -185,6 +185,8 @@ class BasicTest(TestCase): resp.read() except httplib.IncompleteRead, i: self.assertEquals(i.partial, 'hello world') + self.assertEqual(repr(i),'IncompleteRead(11 bytes read)') + self.assertEqual(str(i),'IncompleteRead(11 bytes read)') else: self.fail('IncompleteRead expected') finally: @@ -198,6 +200,23 @@ class BasicTest(TestCase): self.assertEquals(resp.read(), 'Hello\r\n') resp.close() + def test_incomplete_read(self): + sock = FakeSocket('HTTP/1.1 200 OK\r\nContent-Length: 10\r\n\r\nHello\r\n') + resp = httplib.HTTPResponse(sock, method="GET") + resp.begin() + try: + resp.read() + except httplib.IncompleteRead as i: + self.assertEquals(i.partial, 'Hello\r\n') + self.assertEqual(repr(i), + "IncompleteRead(7 bytes read, 3 more expected)") + self.assertEqual(str(i), + "IncompleteRead(7 bytes read, 3 more expected)") + else: + self.fail('IncompleteRead expected') + finally: + resp.close() + class OfflineTest(TestCase): def test_responses(self): @@ -765,6 +765,7 @@ Dik Winter Blake Winton Jean-Claude Wippler Lars Wirzenius +Chris Withers Stefan Witzel David Wolever Klaus-Juergen Wolf @@ -168,6 +168,9 @@ Core and Builtins Library ------- +- Issue #4308: httplib.IncompleteRead's repr doesn't include all of the data all + ready received. + - Issue #5401: Fixed a performance problem in mimetypes when ``from mimetypes import guess_extension`` was used. |