summaryrefslogtreecommitdiff
path: root/Lib
diff options
context:
space:
mode:
authorUtkarsh Upadhyay <mail@musicallyut.in>2017-07-21 02:14:54 +0200
committerVictor Stinner <victor.stinner@gmail.com>2017-07-21 02:14:54 +0200
commit287c5594edc1ca08db64d1f4739cc36bfe75ae75 (patch)
tree67a8421d302c773765a452012e2317041cffd118 /Lib
parentfff2a21057b98732562098e3bdd65980551f0135 (diff)
downloadcpython-git-287c5594edc1ca08db64d1f4739cc36bfe75ae75.tar.gz
bpo-30822: Fix testing of datetime module. (#2530) (#2783)
Only C implementation was tested.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/datetime.py3
-rw-r--r--Lib/test/datetimetester.py12
-rw-r--r--Lib/test/test_datetime.py8
3 files changed, 14 insertions, 9 deletions
diff --git a/Lib/datetime.py b/Lib/datetime.py
index 5d5579c1c6..b95536fb7a 100644
--- a/Lib/datetime.py
+++ b/Lib/datetime.py
@@ -2271,7 +2271,8 @@ else:
_check_tzinfo_arg, _check_tzname, _check_utc_offset, _cmp, _cmperror,
_date_class, _days_before_month, _days_before_year, _days_in_month,
_format_time, _is_leap, _isoweek1monday, _math, _ord2ymd,
- _time, _time_class, _tzinfo_class, _wrap_strftime, _ymd2ord)
+ _time, _time_class, _tzinfo_class, _wrap_strftime, _ymd2ord,
+ _divide_and_round)
# XXX Since import * above excludes names that start with _,
# docstring does not get overwritten. In the future, it may be
# appropriate to maintain a single module level docstring and
diff --git a/Lib/test/datetimetester.py b/Lib/test/datetimetester.py
index bccd97aa3c..b25e6c1713 100644
--- a/Lib/test/datetimetester.py
+++ b/Lib/test/datetimetester.py
@@ -61,8 +61,9 @@ class TestModule(unittest.TestCase):
self.assertEqual(datetime.MAXYEAR, 9999)
def test_name_cleanup(self):
- if '_Fast' not in str(self):
- return
+ if '_Pure' in self.__class__.__name__:
+ self.skipTest('Only run for Fast C implementation')
+
datetime = datetime_module
names = set(name for name in dir(datetime)
if not name.startswith('__') and not name.endswith('__'))
@@ -72,8 +73,9 @@ class TestModule(unittest.TestCase):
self.assertEqual(names - allowed, set([]))
def test_divide_and_round(self):
- if '_Fast' in str(self):
- return
+ if '_Fast' in self.__class__.__name__:
+ self.skipTest('Only run for Pure Python implementation')
+
dar = datetime_module._divide_and_round
self.assertEqual(dar(-10, -3), 3)
@@ -2851,7 +2853,7 @@ class TestTimeTZ(TestTime, TZInfoBase, unittest.TestCase):
self.assertRaises(TypeError, t.strftime, "%Z")
# Issue #6697:
- if '_Fast' in str(self):
+ if '_Fast' in self.__class__.__name__:
Badtzname.tz = '\ud800'
self.assertRaises(ValueError, t.strftime, "%Z")
diff --git a/Lib/test/test_datetime.py b/Lib/test/test_datetime.py
index 04f11c80ec..d659f369d5 100644
--- a/Lib/test/test_datetime.py
+++ b/Lib/test/test_datetime.py
@@ -20,7 +20,7 @@ test_suffixes = ["_Pure", "_Fast"]
# XXX(gb) First run all the _Pure tests, then all the _Fast tests. You might
# not believe this, but in spite of all the sys.modules trickery running a _Pure
# test last will leave a mix of pure and native datetime stuff lying around.
-test_classes = []
+all_test_classes = []
for module, suffix in zip(test_modules, test_suffixes):
test_classes = []
@@ -34,7 +34,8 @@ for module, suffix in zip(test_modules, test_suffixes):
test_classes.extend(type(test) for test in suit)
test_classes = sorted(set(test_classes), key=lambda cls: cls.__qualname__)
for cls in test_classes:
- cls.__name__ = name + suffix
+ cls.__name__ += suffix
+ cls.__qualname__ += suffix
@classmethod
def setUpClass(cls_, module=module):
cls_._save_sys_modules = sys.modules.copy()
@@ -47,9 +48,10 @@ for module, suffix in zip(test_modules, test_suffixes):
sys.modules.update(cls_._save_sys_modules)
cls.setUpClass = setUpClass
cls.tearDownClass = tearDownClass
+ all_test_classes.extend(test_classes)
def test_main():
- run_unittest(*test_classes)
+ run_unittest(*all_test_classes)
if __name__ == "__main__":
test_main()