Add test case for the HTTPResponse being an iterable. Follow-up of issue #4608.

This commit is contained in:
Florent Xicluna 2010-08-08 16:25:27 +00:00
parent e3f76168a9
commit 37d3d9aa96
1 changed files with 22 additions and 2 deletions

View File

@ -308,8 +308,9 @@ def GetRequestHandler(responses):
def do_GET(self):
body = self.send_head()
if body:
self.wfile.write(body)
while body:
done = self.wfile.write(body)
body = body[done:]
def do_POST(self):
content_length = self.headers["Content-Length"]
@ -501,6 +502,25 @@ class TestUrlopen(BaseTestCase):
urllib.request.urlopen,
"http://sadflkjsasf.i.nvali.d./")
def test_iteration(self):
expected_response = b"pycon 2008..."
handler = self.start_server([(200, [], expected_response)])
data = urllib.request.urlopen("http://localhost:%s" % handler.port)
for line in data:
self.assertEqual(line, expected_response)
def test_line_iteration(self):
lines = [b"We\n", b"got\n", b"here\n", b"verylong " * 8192 + b"\n"]
expected_response = b"".join(lines)
handler = self.start_server([(200, [], expected_response)])
data = urllib.request.urlopen("http://localhost:%s" % handler.port)
for index, line in enumerate(data):
self.assertEqual(line, lines[index],
"Fetched line number %s doesn't match expected:\n"
" Expected length was %s, got %s" %
(index, len(lines[index]), len(line)))
self.assertEqual(index + 1, len(lines))
def test_main():
support.run_unittest(ProxyAuthTests, TestUrlopen)