diff options
Diffstat (limited to 'Lib/test/test_urllibnet.py')
-rw-r--r-- | Lib/test/test_urllibnet.py | 192 |
1 files changed, 85 insertions, 107 deletions
diff --git a/Lib/test/test_urllibnet.py b/Lib/test/test_urllibnet.py index 1d88331146a..383b2affd09 100644 --- a/Lib/test/test_urllibnet.py +++ b/Lib/test/test_urllibnet.py @@ -1,33 +1,21 @@ -#!/usr/bin/env python +#!/usr/bin/env python3 import unittest -from test import test_support +from test import support +import contextlib import socket -import urllib +import urllib.request import sys import os +import email.message import time -mimetools = test_support.import_module("mimetools", deprecated=True) - - -def _open_with_retry(func, host, *args, **kwargs): - # Connecting to remote hosts is flaky. Make it more robust - # by retrying the connection several times. - for i in range(3): - try: - return func(host, *args, **kwargs) - except IOError, last_exc: - continue - except: - raise - raise last_exc - class URLTimeoutTest(unittest.TestCase): + # XXX this test doesn't seem to test anything useful. - TIMEOUT = 10.0 + TIMEOUT = 30.0 def setUp(self): socket.setdefaulttimeout(self.TIMEOUT) @@ -36,11 +24,13 @@ class URLTimeoutTest(unittest.TestCase): socket.setdefaulttimeout(None) def testURLread(self): - f = _open_with_retry(urllib.urlopen, "http://www.python.org/") - x = f.read() + with support.transient_internet("www.python.org"): + f = urllib.request.urlopen("http://www.python.org/") + x = f.read() + class urlopenNetworkTests(unittest.TestCase): - """Tests urllib.urlopen using the network. + """Tests urllib.reqest.urlopen using the network. These tests are not exhaustive. Assuming that testing using files does a good job overall of some of the basic interface features. There are no @@ -54,79 +44,71 @@ class urlopenNetworkTests(unittest.TestCase): """ - def urlopen(self, *args): - return _open_with_retry(urllib.urlopen, *args) + @contextlib.contextmanager + def urlopen(self, *args, **kwargs): + resource = args[0] + with support.transient_internet(resource): + r = urllib.request.urlopen(*args, **kwargs) + try: + yield r + finally: + r.close() def test_basic(self): # Simple test expected to pass. - open_url = self.urlopen("http://www.python.org/") - for attr in ("read", "readline", "readlines", "fileno", "close", - "info", "geturl"): - self.assertTrue(hasattr(open_url, attr), "object returned from " - "urlopen lacks the %s attribute" % attr) - try: + with self.urlopen("http://www.python.org/") as open_url: + for attr in ("read", "readline", "readlines", "fileno", "close", + "info", "geturl"): + self.assertTrue(hasattr(open_url, attr), "object returned from " + "urlopen lacks the %s attribute" % attr) self.assertTrue(open_url.read(), "calling 'read' failed") - finally: - open_url.close() def test_readlines(self): # Test both readline and readlines. - open_url = self.urlopen("http://www.python.org/") - try: - self.assertIsInstance(open_url.readline(), basestring, + with self.urlopen("http://www.python.org/") as open_url: + self.assertIsInstance(open_url.readline(), bytes, "readline did not return a string") self.assertIsInstance(open_url.readlines(), list, "readlines did not return a list") - finally: - open_url.close() def test_info(self): # Test 'info'. - open_url = self.urlopen("http://www.python.org/") - try: + with self.urlopen("http://www.python.org/") as open_url: info_obj = open_url.info() - finally: - open_url.close() - self.assertIsInstance(info_obj, mimetools.Message, + self.assertIsInstance(info_obj, email.message.Message, "object returned by 'info' is not an " - "instance of mimetools.Message") - self.assertEqual(info_obj.getsubtype(), "html") + "instance of email.message.Message") + self.assertEqual(info_obj.get_content_subtype(), "html") def test_geturl(self): # Make sure same URL as opened is returned by geturl. URL = "http://www.python.org/" - open_url = self.urlopen(URL) - try: + with self.urlopen(URL) as open_url: gotten_url = open_url.geturl() - finally: - open_url.close() - self.assertEqual(gotten_url, URL) + self.assertEqual(gotten_url, URL) def test_getcode(self): # test getcode() with the fancy opener to get 404 error codes URL = "http://www.python.org/XXXinvalidXXX" - open_url = urllib.FancyURLopener().open(URL) - try: - code = open_url.getcode() - finally: - open_url.close() - self.assertEqual(code, 404) + with support.transient_internet(URL): + open_url = urllib.request.FancyURLopener().open(URL) + try: + code = open_url.getcode() + finally: + open_url.close() + self.assertEqual(code, 404) def test_fileno(self): - if (sys.platform in ('win32',) or - not hasattr(os, 'fdopen')): + if sys.platform in ('win32',): # On Windows, socket handles are not file descriptors; this # test can't pass on Windows. return # Make sure fd returned by fileno is valid. - open_url = self.urlopen("http://www.python.org/") - fd = open_url.fileno() - FILE = os.fdopen(fd) - try: - self.assertTrue(FILE.read(), "reading from file created using fd " - "returned by fileno failed") - finally: - FILE.close() + with self.urlopen("http://www.python.org/", timeout=None) as open_url: + fd = open_url.fileno() + with os.fdopen(fd, encoding='utf-8') as f: + self.assertTrue(f.read(), "reading from file created using fd " + "returned by fileno failed") def test_bad_address(self): # Make sure proper exception is raised when connecting to a bogus @@ -147,67 +129,63 @@ class urlopenNetworkTests(unittest.TestCase): # domain will be spared to serve its defined # purpose. # urllib.urlopen, "http://www.sadflkjsasadf.com/") - urllib.urlopen, "http://sadflkjsasf.i.nvali.d/") + urllib.request.urlopen, + "http://sadflkjsasf.i.nvali.d/") + class urlretrieveNetworkTests(unittest.TestCase): - """Tests urllib.urlretrieve using the network.""" + """Tests urllib.request.urlretrieve using the network.""" + @contextlib.contextmanager def urlretrieve(self, *args): - return _open_with_retry(urllib.urlretrieve, *args) + resource = args[0] + with support.transient_internet(resource): + file_location, info = urllib.request.urlretrieve(*args) + try: + yield file_location, info + finally: + support.unlink(file_location) def test_basic(self): # Test basic functionality. - file_location,info = self.urlretrieve("http://www.python.org/") - self.assertTrue(os.path.exists(file_location), "file location returned by" - " urlretrieve is not a valid path") - FILE = file(file_location) - try: - self.assertTrue(FILE.read(), "reading from the file location returned" - " by urlretrieve failed") - finally: - FILE.close() - os.unlink(file_location) + with self.urlretrieve("http://www.python.org/") as (file_location, info): + self.assertTrue(os.path.exists(file_location), "file location returned by" + " urlretrieve is not a valid path") + with open(file_location, encoding='utf-8') as f: + self.assertTrue(f.read(), "reading from the file location returned" + " by urlretrieve failed") def test_specified_path(self): # Make sure that specifying the location of the file to write to works. - file_location,info = self.urlretrieve("http://www.python.org/", - test_support.TESTFN) - self.assertEqual(file_location, test_support.TESTFN) - self.assertTrue(os.path.exists(file_location)) - FILE = file(file_location) - try: - self.assertTrue(FILE.read(), "reading from temporary file failed") - finally: - FILE.close() - os.unlink(file_location) + with self.urlretrieve("http://www.python.org/", + support.TESTFN) as (file_location, info): + self.assertEqual(file_location, support.TESTFN) + self.assertTrue(os.path.exists(file_location)) + with open(file_location, encoding='utf-8') as f: + self.assertTrue(f.read(), "reading from temporary file failed") def test_header(self): # Make sure header returned as 2nd value from urlretrieve is good. - file_location, header = self.urlretrieve("http://www.python.org/") - os.unlink(file_location) - self.assertIsInstance(header, mimetools.Message, - "header is not an instance of mimetools.Message") + with self.urlretrieve("http://www.python.org/") as (file_location, info): + self.assertIsInstance(info, email.message.Message, + "info is not an instance of email.message.Message") def test_data_header(self): logo = "http://www.python.org/community/logos/python-logo-master-v3-TM.png" - file_location, fileheaders = self.urlretrieve(logo) - os.unlink(file_location) - datevalue = fileheaders.getheader('Date') - dateformat = '%a, %d %b %Y %H:%M:%S GMT' - try: - time.strptime(datevalue, dateformat) - except ValueError: - self.fail('Date value not in %r format', dateformat) - + with self.urlretrieve(logo) as (file_location, fileheaders): + datevalue = fileheaders.get('Date') + dateformat = '%a, %d %b %Y %H:%M:%S GMT' + try: + time.strptime(datevalue, dateformat) + except ValueError: + self.fail('Date value not in %r format', dateformat) def test_main(): - test_support.requires('network') - with test_support.check_py3k_warnings( - ("urllib.urlopen.. has been removed", DeprecationWarning)): - test_support.run_unittest(URLTimeoutTest, - urlopenNetworkTests, - urlretrieveNetworkTests) + support.requires('network') + support.run_unittest(URLTimeoutTest, + urlopenNetworkTests, + urlretrieveNetworkTests) if __name__ == "__main__": test_main() |