]> granicus.if.org Git - python/commitdiff
Issue #13847: Make test_localtime_failure() more robust
authorVictor Stinner <victor.stinner@haypocalc.com>
Fri, 27 Jan 2012 00:03:25 +0000 (01:03 +0100)
committerVictor Stinner <victor.stinner@haypocalc.com>
Fri, 27 Jan 2012 00:03:25 +0000 (01:03 +0100)
Skip the test if we are unable to find an invalid time_t value.

Lib/test/test_time.py

index 292cb8545fd0c5a77afa1382fde7ee20f2e030aa..e3298d5e3d21b189b0db9d4b2a6eecce8f3580c7 100644 (file)
@@ -345,16 +345,21 @@ class TimeTestCase(unittest.TestCase):
 
     def test_localtime_failure(self):
         # Issue #13847: check for localtime() failure
-        invalid_time_t = 2**60
-        try:
-            time.localtime(invalid_time_t)
-        except ValueError as err:
-            if str(err) == "timestamp out of range for platform time_t":
-                self.skipTest("need 64-bit time_t")
-            else:
-                raise
-        except OSError:
-            pass
+        invalid_time_t = None
+        for time_t in (-1, 2**30, 2**33, 2**60):
+            try:
+                time.localtime(time_t)
+            except ValueError as err:
+                if str(err) == "timestamp out of range for platform time_t":
+                    self.skipTest("need 64-bit time_t")
+                else:
+                    raise
+            except OSError:
+                invalid_time_t = time_t
+                break
+        if invalid_time_t is None:
+            self.skipTest("unable to find an invalid time_t value")
+
         self.assertRaises(OSError, time.localtime, invalid_time_t)
         self.assertRaises(OSError, time.gmtime, invalid_time_t)
         self.assertRaises(OSError, time.ctime, invalid_time_t)