diff options
author | Victor Stinner <victor.stinner@haypocalc.com> | 2011-01-08 03:06:52 (GMT) |
---|---|---|
committer | Victor Stinner <victor.stinner@haypocalc.com> | 2011-01-08 03:06:52 (GMT) |
commit | 301f1217ac18e612c71e18f8fbebbdf31727eb47 (patch) | |
tree | 5427416790cacdadf4cec3ccc2978c925ef2679f | |
parent | af5aee57c98d4529218c517ee6d73c3f78bc6738 (diff) | |
download | cpython-301f1217ac18e612c71e18f8fbebbdf31727eb47.zip cpython-301f1217ac18e612c71e18f8fbebbdf31727eb47.tar.gz cpython-301f1217ac18e612c71e18f8fbebbdf31727eb47.tar.bz2 |
Issue #1777412: Remove all limits on tm_year from time.strftime()
The buildbots will tell us which platform does support or not negative years.
-rw-r--r-- | Lib/test/test_time.py | 36 | ||||
-rw-r--r-- | Modules/timemodule.c | 9 |
2 files changed, 20 insertions, 25 deletions
diff --git a/Lib/test/test_time.py b/Lib/test/test_time.py index 9f36c9d..baabfbb 100644 --- a/Lib/test/test_time.py +++ b/Lib/test/test_time.py @@ -294,21 +294,13 @@ class _TestStrftimeYear: text = self.yearstr(12345) except ValueError: # strftime() is limited to [1; 9999] with Visual Studio - pass - else: - # Issue #10864: OpenIndiana is limited to 4 digits, but Python - # doesn't raise a ValueError - #self.assertEqual(text, '12345') - self.assertIn(text, ('2345', '12345')) - try: - text = self.yearstr(123456789) - except ValueError: - pass - else: - # Issue #10864: OpenIndiana is limited to 4 digits, but Python - # doesn't raise a ValueError - #self.assertEqual(text, '123456789') - self.assertIn(text, ('123456789', '6789')) + return + # Issue #10864: OpenIndiana is limited to 4 digits, + # but Python doesn't raise a ValueError + #self.assertEqual(text, '12345') + #self.assertEqual(self.yearstr(123456789), '123456789') + self.assertIn(text, ('2345', '12345')) + self.assertIn(self.yearstr(123456789), ('123456789', '6789')) class _Test2dYear(_BaseYearTest): accept2dyear = 1 @@ -336,6 +328,17 @@ class _Test4dYear(_BaseYearTest): self.assertIn(self.yearstr(999), ('999', '0999')) self.assertEqual(self.yearstr(9999), '9999') + def test_negative(self): + try: + text = self.yearstr(-1) + except ValueError: + # strftime() is limited to [1; 9999] with Visual Studio + return + self.assertIn(text, ('-1', '-001')) + + self.assertEqual(self.yearstr(-1234), '-1234') + self.assertEqual(self.yearstr(-123456), '-123456') + class TestAsctimeAccept2dYear(_TestAsctimeYear, _Test2dYear): pass @@ -346,8 +349,7 @@ class TestAsctime4dyear(_TestAsctimeYear, _Test4dYear): pass class TestStrftime4dyear(_TestStrftimeYear, _Test4dYear): - def test_bounds(self): - self.assertRaises(ValueError, self.yearstr, 0) + pass class Test2dyearBool(_TestAsctimeYear, _Test2dYear): accept2dyear = True diff --git a/Modules/timemodule.c b/Modules/timemodule.c index de1588f..314d8c3 100644 --- a/Modules/timemodule.c +++ b/Modules/timemodule.c @@ -332,7 +332,7 @@ gettmarg(PyObject *args, struct tm *p) if (y < 1000) { PyObject *accept = PyDict_GetItemString(moddict, "accept2dyear"); - if (accept != NULL) { + if (accept != NULL) { int acceptval = PyObject_IsTrue(accept); if (acceptval == -1) return 0; @@ -481,13 +481,6 @@ time_strftime(PyObject *self, PyObject *args) buf.tm_year + 1900); return NULL; } -#else - if (buf.tm_year + 1900 < 1) { - PyErr_Format(PyExc_ValueError, - "strftime() requires year >= 1", - buf.tm_year + 1900); - return NULL; - } #endif /* Normalize tm_isdst just in case someone foolishly implements %Z |