diff options
| author | Victor Stinner <victor.stinner@gmail.com> | 2015-09-10 09:10:14 +0200 | 
|---|---|---|
| committer | Victor Stinner <victor.stinner@gmail.com> | 2015-09-10 09:10:14 +0200 | 
| commit | 9c72f9b30a60d09c10b6cde23bd4b0546c6947af (patch) | |
| tree | 7428046c934667df998da7d5412920b7c441ab36 /Lib/test/test_time.py | |
| parent | 4f1f6e4618fa4c054377f78425f07b1e4409c832 (diff) | |
| download | cpython-git-9c72f9b30a60d09c10b6cde23bd4b0546c6947af.tar.gz | |
Fix test_time on Windows
* Filter values which would overflow on conversion to the C long type
  (for timeval.tv_sec).
* Adjust also the message of OverflowError on PyTime conversions
* test_time: add debug information if a timestamp conversion fails
Diffstat (limited to 'Lib/test/test_time.py')
| -rw-r--r-- | Lib/test/test_time.py | 33 | 
1 files changed, 24 insertions, 9 deletions
| diff --git a/Lib/test/test_time.py b/Lib/test/test_time.py index bd697aeb13..7f1613b7ce 100644 --- a/Lib/test/test_time.py +++ b/Lib/test/test_time.py @@ -756,10 +756,15 @@ class CPyTimeTestCase:              context.rounding = decimal_rnd              for value in valid_values: -                expected = expected_func(value) -                self.assertEqual(pytime_converter(value, time_rnd), +                debug_info = {'value': value, 'rounding': decimal_rnd} +                try: +                    result = pytime_converter(value, time_rnd) +                    expected = expected_func(value) +                except Exception as exc: +                    self.fail("Error on timestamp conversion: %s" % debug_info) +                self.assertEqual(result,                                   expected, -                                 {'value': value, 'rounding': decimal_rnd}) +                                 debug_info)          # test overflow          ns = self.OVERFLOW_SECONDS * SEC_TO_NS @@ -770,14 +775,15 @@ class CPyTimeTestCase:                  with self.assertRaises(OverflowError):                      pytime_converter(value, time_rnd) -    def check_int_rounding(self, pytime_converter, expected_func, unit_to_sec=1, -                           value_filter=None): +    def check_int_rounding(self, pytime_converter, expected_func, +                           unit_to_sec=1, value_filter=None):          self._check_rounding(pytime_converter, expected_func,                               False, unit_to_sec, value_filter) -    def check_float_rounding(self, pytime_converter, expected_func, unit_to_sec=1): +    def check_float_rounding(self, pytime_converter, expected_func, +                             unit_to_sec=1, value_filter=None):          self._check_rounding(pytime_converter, expected_func, -                             True, unit_to_sec) +                             True, unit_to_sec, value_filter)      def decimal_round(self, x):          d = decimal.Decimal(x) @@ -845,9 +851,19 @@ class TestCPyTime(CPyTimeTestCase, unittest.TestCase):              us = us_converter(ns)              return divmod(us, SEC_TO_US) +        if sys.platform == 'win32': +            from _testcapi import LONG_MIN, LONG_MAX + +            # On Windows, timeval.tv_sec type is a C long +            def seconds_filter(secs): +                return LONG_MIN <= secs <= LONG_MAX +        else: +            seconds_filter = None +          self.check_int_rounding(PyTime_AsTimeval,                                  timeval_converter, -                                NS_TO_SEC) +                                NS_TO_SEC, +                                value_filter=seconds_filter)      @unittest.skipUnless(hasattr(_testcapi, 'PyTime_AsTimespec'),                           'need _testcapi.PyTime_AsTimespec') @@ -927,6 +943,5 @@ class TestOldPyTime(CPyTimeTestCase, unittest.TestCase):                                    self.create_converter(SEC_TO_NS)) -  if __name__ == "__main__":      unittest.main() | 
