Kaydet (Commit) 5c85e3f3 authored tarafından Victor Stinner's avatar Victor Stinner

test_timeout: move testRecvfromTimeout() to a UDP-specific test case

Fix a ResourceWarning(unclosed socket).
üst 109761ba
...@@ -88,8 +88,6 @@ class CreationTestCase(unittest.TestCase): ...@@ -88,8 +88,6 @@ class CreationTestCase(unittest.TestCase):
class TimeoutTestCase(unittest.TestCase): class TimeoutTestCase(unittest.TestCase):
"""Test case for socket.socket() timeout functions"""
# There are a number of tests here trying to make sure that an operation # There are a number of tests here trying to make sure that an operation
# doesn't take too much longer than expected. But competing machine # doesn't take too much longer than expected. But competing machine
# activity makes it inevitable that such tests will fail at times. # activity makes it inevitable that such tests will fail at times.
...@@ -98,14 +96,22 @@ class TimeoutTestCase(unittest.TestCase): ...@@ -98,14 +96,22 @@ class TimeoutTestCase(unittest.TestCase):
# solution. # solution.
fuzz = 2.0 fuzz = 2.0
localhost = '127.0.0.1'
def setUp(self): def setUp(self):
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) raise NotImplementedError()
self.addr_remote = ('www.python.org.', 80)
self.localhost = '127.0.0.1'
def tearDown(self): def tearDown(self):
self.sock.close() self.sock.close()
class TCPTimeoutTestCase(TimeoutTestCase):
"""TCP test case for socket.socket() timeout functions"""
def setUp(self):
self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
self.addr_remote = ('www.python.org.', 80)
def testConnectTimeout(self): def testConnectTimeout(self):
# Choose a private address that is unlikely to exist to prevent # Choose a private address that is unlikely to exist to prevent
# failures due to the connect succeeding before the timeout. # failures due to the connect succeeding before the timeout.
...@@ -161,10 +167,31 @@ class TimeoutTestCase(unittest.TestCase): ...@@ -161,10 +167,31 @@ class TimeoutTestCase(unittest.TestCase):
"timeout (%g) is %g seconds more than expected (%g)" "timeout (%g) is %g seconds more than expected (%g)"
%(_delta, self.fuzz, _timeout)) %(_delta, self.fuzz, _timeout))
def testSend(self):
# Test send() timeout
# couldn't figure out how to test it
pass
def testSendto(self):
# Test sendto() timeout
# couldn't figure out how to test it
pass
def testSendall(self):
# Test sendall() timeout
# couldn't figure out how to test it
pass
class UDPTimeoutTestCase(TimeoutTestCase):
"""UDP test case for socket.socket() timeout functions"""
def setUp(self):
self.sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
def testRecvfromTimeout(self): def testRecvfromTimeout(self):
# Test recvfrom() timeout # Test recvfrom() timeout
_timeout = 2 _timeout = 2
self.sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
self.sock.settimeout(_timeout) self.sock.settimeout(_timeout)
# Prevent "Address already in use" socket exceptions # Prevent "Address already in use" socket exceptions
support.bind_port(self.sock, self.localhost) support.bind_port(self.sock, self.localhost)
...@@ -178,25 +205,14 @@ class TimeoutTestCase(unittest.TestCase): ...@@ -178,25 +205,14 @@ class TimeoutTestCase(unittest.TestCase):
"timeout (%g) is %g seconds more than expected (%g)" "timeout (%g) is %g seconds more than expected (%g)"
%(_delta, self.fuzz, _timeout)) %(_delta, self.fuzz, _timeout))
def testSend(self):
# Test send() timeout
# couldn't figure out how to test it
pass
def testSendto(self):
# Test sendto() timeout
# couldn't figure out how to test it
pass
def testSendall(self):
# Test sendall() timeout
# couldn't figure out how to test it
pass
def test_main(): def test_main():
support.requires('network') support.requires('network')
support.run_unittest(CreationTestCase, TimeoutTestCase) support.run_unittest(
CreationTestCase,
TCPTimeoutTestCase,
UDPTimeoutTestCase,
)
if __name__ == "__main__": if __name__ == "__main__":
test_main() test_main()
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