]> granicus.if.org Git - python/commitdiff
Issue #7547: fix transient failures due to network glitches in test_timeout.
authorAntoine Pitrou <solipsis@pitrou.net>
Fri, 29 Oct 2010 18:15:33 +0000 (18:15 +0000)
committerAntoine Pitrou <solipsis@pitrou.net>
Fri, 29 Oct 2010 18:15:33 +0000 (18:15 +0000)
Patch by Sandro Tosi.

Lib/test/test_timeout.py

index b67cbc92f213bf9585f011d6f493767058712f96..bbcdc25672ac56cb7da8f28994649a5f7fb3992b 100644 (file)
@@ -130,17 +130,19 @@ class TimeoutTestCase(unittest.TestCase):
     def testRecvTimeout(self):
         # Test recv() timeout
         _timeout = 0.02
-        self.sock.connect(self.addr_remote)
-        self.sock.settimeout(_timeout)
 
-        _t1 = time.time()
-        self.assertRaises(socket.error, self.sock.recv, 1024)
-        _t2 = time.time()
+        with support.transient_internet(self.addr_remote[0]):
+            self.sock.connect(self.addr_remote)
+            self.sock.settimeout(_timeout)
 
-        _delta = abs(_t1 - _t2)
-        self.assertTrue(_delta < _timeout + self.fuzz,
-                     "timeout (%g) is %g seconds more than expected (%g)"
-                     %(_delta, self.fuzz, _timeout))
+            _t1 = time.time()
+            self.assertRaises(socket.timeout, self.sock.recv, 1024)
+            _t2 = time.time()
+
+            _delta = abs(_t1 - _t2)
+            self.assertTrue(_delta < _timeout + self.fuzz,
+                         "timeout (%g) is %g seconds more than expected (%g)"
+                         %(_delta, self.fuzz, _timeout))
 
     def testAcceptTimeout(self):
         # Test accept() timeout