]> granicus.if.org Git - python/commitdiff
#3571: try to fix recurrent buildbot failures by strenghtening test_os.test_closerange
authorAntoine Pitrou <solipsis@pitrou.net>
Sat, 16 Aug 2008 22:03:17 +0000 (22:03 +0000)
committerAntoine Pitrou <solipsis@pitrou.net>
Sat, 16 Aug 2008 22:03:17 +0000 (22:03 +0000)
Lib/test/test_os.py

index 09270e10f8ab7aac46a3bed9ed426e9c1cfd2cf8..ca23dbac85efd777dec8734999566063e2ecf3c3 100644 (file)
@@ -21,10 +21,27 @@ class FileTests(unittest.TestCase):
         self.assert_(os.access(support.TESTFN, os.W_OK))
 
     def test_closerange(self):
-        f = os.open(support.TESTFN, os.O_CREAT|os.O_RDWR)
+        first = os.open(support.TESTFN, os.O_CREAT|os.O_RDWR)
+        # We must allocate two consecutive file descriptors, otherwise
+        # it will mess up other file descriptors (perhaps even the three
+        # standard ones).
+        second = os.dup(first)
+        try:
+            retries = 0
+            while second != first + 1:
+                os.close(first)
+                retries += 1
+                if retries > 10:
+                    # XXX test skipped
+                    print("couldn't allocate two consecutive fds, "
+                        "skipping test_closerange", file=sys.stderr)
+                    return
+                first, second = second, os.dup(second)
+        finally:
+            os.close(second)
         # close a fd that is open, and one that isn't
-        os.closerange(f, f+2)
-        self.assertRaises(OSError, os.write, f, "a")
+        os.closerange(first, first + 2)
+        self.assertRaises(OSError, os.write, first, "a")
 
 class TemporaryFileTests(unittest.TestCase):
     def setUp(self):