diff options
| author | Victor Stinner <victor.stinner@gmail.com> | 2015-09-04 10:31:16 +0200 | 
|---|---|---|
| committer | Victor Stinner <victor.stinner@gmail.com> | 2015-09-04 10:31:16 +0200 | 
| commit | 110f9e35383373022b169756e64974814733aef4 (patch) | |
| tree | 9d669ab525f00649f16ab128bb1fc0c27c9cf322 /Lib/test/test_time.py | |
| parent | 1320f08b408093324be54fb078c45178289d18fb (diff) | |
| download | cpython-git-110f9e35383373022b169756e64974814733aef4.tar.gz | |
test_time: add tests on HALF_UP rounding mode for _PyTime_ObjectToTime_t() and
_PyTime_ObjectToTimespec()
Diffstat (limited to 'Lib/test/test_time.py')
| -rw-r--r-- | Lib/test/test_time.py | 130 | 
1 files changed, 90 insertions, 40 deletions
| diff --git a/Lib/test/test_time.py b/Lib/test/test_time.py index 5947f4041f..590425ae90 100644 --- a/Lib/test/test_time.py +++ b/Lib/test/test_time.py @@ -606,24 +606,49 @@ class TestPytime(unittest.TestCase):      @support.cpython_only      def test_time_t(self):          from _testcapi import pytime_object_to_time_t + +        # Conversion giving the same result for all rounding methods +        for rnd in ALL_ROUNDING_METHODS: +            for obj, seconds in ( +                # int +                (-1, -1), +                (0, 0), +                (1, 1), + +                # float +                (-1.0, -1), +                (1.0, 1), +            ): +                with self.subTest(obj=obj, round=rnd, seconds=seconds): +                    self.assertEqual(pytime_object_to_time_t(obj, rnd), +                                     seconds) + +        # Conversion giving different results depending on the rounding method +        FLOOR = _PyTime.ROUND_FLOOR +        CEILING = _PyTime.ROUND_CEILING +        HALF_UP =  _PyTime.ROUND_HALF_UP          for obj, time_t, rnd in ( -            # Round towards minus infinity (-inf) -            (0, 0, _PyTime.ROUND_FLOOR), -            (-1, -1, _PyTime.ROUND_FLOOR), -            (-1.0, -1, _PyTime.ROUND_FLOOR), -            (-1.9, -2, _PyTime.ROUND_FLOOR), -            (1.0, 1, _PyTime.ROUND_FLOOR), -            (1.9, 1, _PyTime.ROUND_FLOOR), -            # Round towards infinity (+inf) -            (0, 0, _PyTime.ROUND_CEILING), -            (-1, -1, _PyTime.ROUND_CEILING), -            (-1.0, -1, _PyTime.ROUND_CEILING), -            (-1.9, -1, _PyTime.ROUND_CEILING), -            (1.0, 1, _PyTime.ROUND_CEILING), -            (1.9, 2, _PyTime.ROUND_CEILING), +            (-1.9, -2, FLOOR), +            (-1.9, -1, CEILING), +            (-1.9, -2, HALF_UP), + +            (1.9, 1, FLOOR), +            (1.9, 2, CEILING), +            (1.9, 2, HALF_UP), + +            # half up +            (-0.999, -1, HALF_UP), +            (-0.510, -1, HALF_UP), +            (-0.500, -1, HALF_UP), +            (-0.490, 0, HALF_UP), +            ( 0.490, 0, HALF_UP), +            ( 0.500, 1, HALF_UP), +            ( 0.510, 1, HALF_UP), +            ( 0.999, 1, HALF_UP),          ):              self.assertEqual(pytime_object_to_time_t(obj, rnd), time_t) +        # Test OverflowError          rnd = _PyTime.ROUND_FLOOR          for invalid in self.invalid_values:              self.assertRaises(OverflowError, @@ -632,39 +657,64 @@ class TestPytime(unittest.TestCase):      @support.cpython_only      def test_timespec(self):          from _testcapi import pytime_object_to_timespec + +        # Conversion giving the same result for all rounding methods +        for rnd in ALL_ROUNDING_METHODS: +            for obj, timespec in ( +                # int +                (0, (0, 0)), +                (-1, (-1, 0)), + +                # float +                (-1.2, (-2, 800000000)), +                (-1.0, (-1, 0)), +                (-1e-9, (-1, 999999999)), +                (1e-9, (0, 1)), +                (1.0, (1, 0)), +            ): +                with self.subTest(obj=obj, round=rnd, timespec=timespec): +                    self.assertEqual(pytime_object_to_timespec(obj, rnd), timespec) + +        # Conversion giving different results depending on the rounding method +        FLOOR = _PyTime.ROUND_FLOOR +        CEILING = _PyTime.ROUND_CEILING +        HALF_UP =  _PyTime.ROUND_HALF_UP          for obj, timespec, rnd in (              # Round towards minus infinity (-inf) -            (0, (0, 0), _PyTime.ROUND_FLOOR), -            (-1, (-1, 0), _PyTime.ROUND_FLOOR), -            (-1.0, (-1, 0), _PyTime.ROUND_FLOOR), -            (1e-9, (0, 1), _PyTime.ROUND_FLOOR), -            (1e-10, (0, 0), _PyTime.ROUND_FLOOR), -            (-1e-9, (-1, 999999999), _PyTime.ROUND_FLOOR), -            (-1e-10, (-1, 999999999), _PyTime.ROUND_FLOOR), -            (-1.2, (-2, 800000000), _PyTime.ROUND_FLOOR), -            (0.9999999999, (0, 999999999), _PyTime.ROUND_FLOOR), -            (1.1234567890, (1, 123456789), _PyTime.ROUND_FLOOR), -            (1.1234567899, (1, 123456789), _PyTime.ROUND_FLOOR), -            (-1.1234567890, (-2, 876543211), _PyTime.ROUND_FLOOR), -            (-1.1234567891, (-2, 876543210), _PyTime.ROUND_FLOOR), +            (-1e-10, (0, 0), CEILING), +            (-1e-10, (-1, 999999999), FLOOR), +            (-1e-10, (0, 0), HALF_UP), +            (1e-10, (0, 0), FLOOR), +            (1e-10, (0, 1), CEILING), +            (1e-10, (0, 0), HALF_UP), + +            (0.9999999999, (0, 999999999), FLOOR), +            (0.9999999999, (1, 0), CEILING), + +            (1.1234567890, (1, 123456789), FLOOR), +            (1.1234567899, (1, 123456789), FLOOR), +            (-1.1234567890, (-2, 876543211), FLOOR), +            (-1.1234567891, (-2, 876543210), FLOOR),              # Round towards infinity (+inf) -            (0, (0, 0), _PyTime.ROUND_CEILING), -            (-1, (-1, 0), _PyTime.ROUND_CEILING), -            (-1.0, (-1, 0), _PyTime.ROUND_CEILING), -            (1e-9, (0, 1), _PyTime.ROUND_CEILING), -            (1e-10, (0, 1), _PyTime.ROUND_CEILING), -            (-1e-9, (-1, 999999999), _PyTime.ROUND_CEILING), -            (-1e-10, (0, 0), _PyTime.ROUND_CEILING), -            (-1.2, (-2, 800000000), _PyTime.ROUND_CEILING), -            (0.9999999999, (1, 0), _PyTime.ROUND_CEILING), -            (1.1234567890, (1, 123456790), _PyTime.ROUND_CEILING), -            (1.1234567899, (1, 123456790), _PyTime.ROUND_CEILING), -            (-1.1234567890, (-2, 876543211), _PyTime.ROUND_CEILING), -            (-1.1234567891, (-2, 876543211), _PyTime.ROUND_CEILING), +            (1.1234567890, (1, 123456790), CEILING), +            (1.1234567899, (1, 123456790), CEILING), +            (-1.1234567890, (-2, 876543211), CEILING), +            (-1.1234567891, (-2, 876543211), CEILING), + +            # half up +            (-0.6e-9, (-1, 999999999), HALF_UP), +            # skipped, 0.5e-6 is inexact in base 2 +            #(-0.5e-9, (-1, 999999999), HALF_UP), +            (-0.4e-9, (0, 0), HALF_UP), + +            (0.4e-9, (0, 0), HALF_UP), +            (0.5e-9, (0, 1), HALF_UP), +            (0.6e-9, (0, 1), HALF_UP),          ):              with self.subTest(obj=obj, round=rnd, timespec=timespec):                  self.assertEqual(pytime_object_to_timespec(obj, rnd), timespec) +        # Test OverflowError          rnd = _PyTime.ROUND_FLOOR          for invalid in self.invalid_values:              self.assertRaises(OverflowError, | 
