mirror of
https://github.com/python/cpython.git
synced 2025-08-04 00:48:58 +00:00

svn+ssh://pythondev@svn.python.org/python/trunk ........ r60131 | georg.brandl | 2008-01-20 12:13:29 +0100 (Sun, 20 Jan 2008) | 3 lines #1351692: in pprint, always call format() for dict and list items to enable custom formatting of contents via subclassing PrettyPrinter. ........ r60133 | georg.brandl | 2008-01-20 12:43:03 +0100 (Sun, 20 Jan 2008) | 2 lines #1178141: add addinfourl.code to get http status code from urllib. ........ r60134 | georg.brandl | 2008-01-20 13:05:43 +0100 (Sun, 20 Jan 2008) | 4 lines #856047: respect the ``no_proxy`` env var when checking for proxies in urllib and using the other ``_proxy`` env vars. Original patch by Donovan Baarda. ........ r60135 | georg.brandl | 2008-01-20 13:18:17 +0100 (Sun, 20 Jan 2008) | 4 lines #1664522: in urllib, don't read non-existing directories in ftp mode, returning a 0-byte file -- raise an IOError instead. Original patch from Phil Knirsch. ........ r60136 | georg.brandl | 2008-01-20 13:57:47 +0100 (Sun, 20 Jan 2008) | 2 lines #799369: document possible sys.platform values. ........ r60137 | georg.brandl | 2008-01-20 14:08:37 +0100 (Sun, 20 Jan 2008) | 2 lines #652749: document the constants added to the builtins by site.py. ........ r60138 | georg.brandl | 2008-01-20 14:59:46 +0100 (Sun, 20 Jan 2008) | 2 lines #1648: add sys.gettrace() and sys.getprofile(). ........ r60139 | georg.brandl | 2008-01-20 15:17:42 +0100 (Sun, 20 Jan 2008) | 2 lines #1669: don't allow shutil.rmtree() to be called on a symlink. ........ r60140 | georg.brandl | 2008-01-20 15:20:02 +0100 (Sun, 20 Jan 2008) | 2 lines Fix test_pyclbr after urllib change. ........ r60141 | christian.heimes | 2008-01-20 15:28:28 +0100 (Sun, 20 Jan 2008) | 1 line Fixed a wrong assumption in configure.in and Include/pyport.h. The is finite function is not called isfinite() but finite(). Sorry, my fault. :) ........ r60142 | georg.brandl | 2008-01-20 15:31:27 +0100 (Sun, 20 Jan 2008) | 2 lines #1876: fix typos in test_operator. ........
170 lines
6.1 KiB
Python
170 lines
6.1 KiB
Python
#!/usr/bin/env python
|
|
|
|
import unittest
|
|
from test import test_support
|
|
|
|
import socket
|
|
import urllib
|
|
import sys
|
|
import os
|
|
import mimetools
|
|
|
|
class URLTimeoutTest(unittest.TestCase):
|
|
|
|
TIMEOUT = 10.0
|
|
|
|
def setUp(self):
|
|
socket.setdefaulttimeout(self.TIMEOUT)
|
|
|
|
def tearDown(self):
|
|
socket.setdefaulttimeout(None)
|
|
|
|
def testURLread(self):
|
|
f = urllib.urlopen("http://www.python.org/")
|
|
x = f.read()
|
|
|
|
class urlopenNetworkTests(unittest.TestCase):
|
|
"""Tests urllib.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
|
|
tests exercising the optional 'data' and 'proxies' arguments. No tests
|
|
for transparent redirection have been written.
|
|
|
|
setUp is not used for always constructing a connection to
|
|
http://www.python.org/ since there a few tests that don't use that address
|
|
and making a connection is expensive enough to warrant minimizing unneeded
|
|
connections.
|
|
|
|
"""
|
|
|
|
def test_basic(self):
|
|
# Simple test expected to pass.
|
|
open_url = urllib.urlopen("http://www.python.org/")
|
|
for attr in ("read", "readline", "readlines", "fileno", "close",
|
|
"info", "geturl"):
|
|
self.assert_(hasattr(open_url, attr), "object returned from "
|
|
"urlopen lacks the %s attribute" % attr)
|
|
try:
|
|
self.assert_(open_url.read(), "calling 'read' failed")
|
|
finally:
|
|
open_url.close()
|
|
|
|
def test_readlines(self):
|
|
# Test both readline and readlines.
|
|
open_url = urllib.urlopen("http://www.python.org/")
|
|
try:
|
|
self.assert_(isinstance(open_url.readline(), bytes),
|
|
"readline did not return bytes")
|
|
self.assert_(isinstance(open_url.readlines(), list),
|
|
"readlines did not return a list")
|
|
finally:
|
|
open_url.close()
|
|
|
|
def test_info(self):
|
|
# Test 'info'.
|
|
open_url = urllib.urlopen("http://www.python.org/")
|
|
try:
|
|
info_obj = open_url.info()
|
|
finally:
|
|
open_url.close()
|
|
self.assert_(isinstance(info_obj, mimetools.Message),
|
|
"object returned by 'info' is not an instance of "
|
|
"mimetools.Message")
|
|
self.assertEqual(info_obj.getsubtype(), "html")
|
|
|
|
def test_geturl(self):
|
|
# Make sure same URL as opened is returned by geturl.
|
|
URL = "http://www.python.org/"
|
|
open_url = urllib.urlopen(URL)
|
|
try:
|
|
gotten_url = open_url.geturl()
|
|
finally:
|
|
open_url.close()
|
|
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)
|
|
|
|
def test_fileno(self):
|
|
if (sys.platform in ('win32',) or
|
|
not hasattr(os, 'fdopen')):
|
|
# 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 = urllib.urlopen("http://www.python.org/")
|
|
fd = open_url.fileno()
|
|
FILE = os.fdopen(fd)
|
|
try:
|
|
self.assert_(FILE.read(), "reading from file created using fd "
|
|
"returned by fileno failed")
|
|
finally:
|
|
FILE.close()
|
|
|
|
def test_bad_address(self):
|
|
# Make sure proper exception is raised when connecting to a bogus
|
|
# address.
|
|
self.assertRaises(IOError,
|
|
# SF patch 809915: In Sep 2003, VeriSign started
|
|
# highjacking invalid .com and .net addresses to
|
|
# boost traffic to their own site. This test
|
|
# started failing then. One hopes the .invalid
|
|
# domain will be spared to serve its defined
|
|
# purpose.
|
|
# urllib.urlopen, "http://www.sadflkjsasadf.com/")
|
|
urllib.urlopen, "http://www.python.invalid./")
|
|
|
|
class urlretrieveNetworkTests(unittest.TestCase):
|
|
"""Tests urllib.urlretrieve using the network."""
|
|
|
|
def test_basic(self):
|
|
# Test basic functionality.
|
|
file_location,info = urllib.urlretrieve("http://www.python.org/")
|
|
self.assert_(os.path.exists(file_location), "file location returned by"
|
|
" urlretrieve is not a valid path")
|
|
FILE = open(file_location)
|
|
try:
|
|
self.assert_(FILE.read(), "reading from the file location returned"
|
|
" by urlretrieve failed")
|
|
finally:
|
|
FILE.close()
|
|
os.unlink(file_location)
|
|
|
|
def test_specified_path(self):
|
|
# Make sure that specifying the location of the file to write to works.
|
|
file_location,info = urllib.urlretrieve("http://www.python.org/",
|
|
test_support.TESTFN)
|
|
self.assertEqual(file_location, test_support.TESTFN)
|
|
self.assert_(os.path.exists(file_location))
|
|
FILE = open(file_location)
|
|
try:
|
|
self.assert_(FILE.read(), "reading from temporary file failed")
|
|
finally:
|
|
FILE.close()
|
|
os.unlink(file_location)
|
|
|
|
def test_header(self):
|
|
# Make sure header returned as 2nd value from urlretrieve is good.
|
|
file_location, header = urllib.urlretrieve("http://www.python.org/")
|
|
os.unlink(file_location)
|
|
self.assert_(isinstance(header, mimetools.Message),
|
|
"header is not an instance of mimetools.Message")
|
|
|
|
|
|
|
|
def test_main():
|
|
test_support.requires('network')
|
|
test_support.run_unittest(URLTimeoutTest,
|
|
urlopenNetworkTests,
|
|
urlretrieveNetworkTests)
|
|
|
|
if __name__ == "__main__":
|
|
test_main()
|