summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorSenthil Kumaran <orsenthil@gmail.com>2011-03-19 09:47:26 (GMT)
committerSenthil Kumaran <orsenthil@gmail.com>2011-03-19 09:47:26 (GMT)
commita4d5b0cb620d8dfc07623f4fe2b551257217589d (patch)
tree3ed334961542acadc356a96f16942d92204aefd8 /Lib
parentf95b4df6d2a73b0e3d6c57215c677c6dd9d95410 (diff)
parentd24c991f11541ccdb3cddade4a59ae0d2c0908bd (diff)
downloadcpython-a4d5b0cb620d8dfc07623f4fe2b551257217589d.zip
cpython-a4d5b0cb620d8dfc07623f4fe2b551257217589d.tar.gz
cpython-a4d5b0cb620d8dfc07623f4fe2b551257217589d.tar.bz2
Closes issue11563 test_urllibnet is triggering a ResourceWarning. Patch by Jeff McNeil.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_urllib.py7
-rw-r--r--Lib/urllib/request.py6
2 files changed, 12 insertions, 1 deletions
diff --git a/Lib/test/test_urllib.py b/Lib/test/test_urllib.py
index 420ff1c..d510e49 100644
--- a/Lib/test/test_urllib.py
+++ b/Lib/test/test_urllib.py
@@ -91,7 +91,7 @@ class urlopen_FileTests(unittest.TestCase):
"did not return the expected text")
def test_close(self):
- # Test close() by calling it hear and then having it be called again
+ # Test close() by calling it here and then having it be called again
# by the tearDown() method for the test
self.returned_obj.close()
@@ -174,6 +174,11 @@ class urlopen_HttpTests(unittest.TestCase):
finally:
self.unfakehttp()
+ def test_willclose(self):
+ self.fakehttp(b"HTTP/1.1 200 OK\r\n\r\nHello!")
+ resp = urlopen("http://www.python.org")
+ self.assertTrue(resp.fp.will_close)
+
def test_read_0_9(self):
# "0.9" response accepted (but not "simple responses" without
# a status line)
diff --git a/Lib/urllib/request.py b/Lib/urllib/request.py
index 96eeb78..a501e37 100644
--- a/Lib/urllib/request.py
+++ b/Lib/urllib/request.py
@@ -1657,6 +1657,12 @@ class URLopener:
headers["Authorization"] = "Basic %s" % auth
if realhost:
headers["Host"] = realhost
+
+ # Add Connection:close as we don't support persistent connections yet.
+ # This helps in closing the socket and avoiding ResourceWarning
+
+ headers["Connection"] = "close"
+
for header, value in self.addheaders:
headers[header] = value