Commit 81323b18 authored by Jason Madden's avatar Jason Madden

Fix test__makefile_ref

parent dfcec573
......@@ -13,6 +13,8 @@ pid = os.getpid()
tmpname = '/tmp/test__makefile_ref.lsof.%s' % pid
lsof_command = 'lsof -p %s > %s' % (pid, tmpname)
import sys
PY3 = sys.version_info[0] >= 3
def get_open_files():
if os.system(lsof_command):
......@@ -77,6 +79,11 @@ class Test(unittest.TestCase):
def assert_closed(self, sock, *rest):
if isinstance(sock, int):
self.assert_fd_closed(sock)
else:
# Under Python3, the socket module returns -1 for a fileno
# of a closed socket; under Py2 it raises
if PY3:
self.assertEqual(sock.fileno(), -1)
else:
self.assert_raises_EBADF(sock.fileno)
self.assert_raises_EBADF(sock.getsockname)
......@@ -103,7 +110,11 @@ class TestSocket(Test):
f = s.makefile()
self.assert_open(s, fileno)
s.close()
# this closes socket wrapper object but not the file descriptor
# Under python 2, this closes socket wrapper object but not the file descriptor;
# under python 3, both stay open
if PY3:
self.assert_open(s, fileno)
else:
self.assert_closed(s)
self.assert_open(fileno)
f.close()
......@@ -169,6 +180,11 @@ class TestSocket(Test):
f = client_socket.makefile()
self.assert_open(client_socket, fileno)
client_socket.close()
# Under python 2, this closes socket wrapper object but not the file descriptor;
# under python 3, both stay open
if PY3:
self.assert_open(client_socket, fileno)
else:
self.assert_closed(client_socket)
self.assert_open(fileno)
f.close()
......@@ -306,6 +322,7 @@ class TestSSL(Test):
self.assert_closed(client_socket, fileno)
finally:
t.join()
connector.close()
def test_server_makefile2(self):
listener = socket.socket()
......@@ -337,6 +354,7 @@ class TestSSL(Test):
finally:
t.join()
listener.close()
connector.close()
def test_serverssl_makefile1(self):
listener = socket.socket()
......@@ -368,6 +386,7 @@ class TestSSL(Test):
finally:
t.join()
listener.close()
connector.close()
def test_serverssl_makefile2(self):
listener = socket.socket()
......@@ -381,7 +400,7 @@ class TestSSL(Test):
def connect():
connector.connect(('127.0.0.1', port))
s = ssl.wrap_socket(connector)
s.sendall('test_serverssl_makefile2')
s.sendall(b'test_serverssl_makefile2')
s.close()
connector.close()
......
......@@ -82,7 +82,6 @@ if PY3:
# No idea / TODO
FAILING_TESTS += '''
test__pywsgi.py
test__makefile_ref.py
FLAKY test__socket_dns.py
'''.strip().split('\n')
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment