From 55329f8fbd7d4beb1483705f8a7bf1419e2eaba6 Mon Sep 17 00:00:00 2001 From: Victor Stinner Date: Sun, 17 Nov 2013 23:39:21 +0100 Subject: [PATCH] Issue #19634: time.strftime("%y") now raises a ValueError on AIX when given a year before 1900. --- Lib/test/test_strftime.py | 16 +++++++--------- Misc/NEWS | 3 +++ Modules/timemodule.c | 14 ++++++++++++++ 3 files changed, 24 insertions(+), 9 deletions(-) diff --git a/Lib/test/test_strftime.py b/Lib/test/test_strftime.py index 61215a15ba3..ff6274e8696 100644 --- a/Lib/test/test_strftime.py +++ b/Lib/test/test_strftime.py @@ -182,15 +182,13 @@ class Y1900Tests(unittest.TestCase): a date before 1900 is passed with a format string containing "%y" """ - @unittest.skipUnless(sys.platform == "win32", "Only applies to Windows") - def test_y_before_1900_win(self): - with self.assertRaises(ValueError): - time.strftime("%y", (1899, 1, 1, 0, 0, 0, 0, 0, 0)) - - @unittest.skipIf(sys.platform == "win32", "Doesn't apply on Windows") - def test_y_before_1900_nonwin(self): - self.assertEqual( - time.strftime("%y", (1899, 1, 1, 0, 0, 0, 0, 0, 0)), "99") + def test_y_before_1900(self): + t = (1899, 1, 1, 0, 0, 0, 0, 0, 0) + if sys.platform == "win32" or sys.platform.startswith("aix"): + with self.assertRaises(ValueError): + time.strftime("%y", t) + else: + self.assertEqual(time.strftime("%y", t), "99") def test_y_1900(self): self.assertEqual( diff --git a/Misc/NEWS b/Misc/NEWS index 58c3033719d..74f58192248 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -50,6 +50,9 @@ Core and Builtins Library ------- +- Issue #19634: time.strftime("%y") now raises a ValueError on AIX when given a + year before 1900. + - Fix test.support.bind_port() to not cause an error when Python was compiled on a system with SO_REUSEPORT defined in the headers but run on a system with an OS kernel that does not support that reasonably new socket option. diff --git a/Modules/timemodule.c b/Modules/timemodule.c index 2e480071bc0..32fe6a7c690 100644 --- a/Modules/timemodule.c +++ b/Modules/timemodule.c @@ -650,6 +650,20 @@ time_strftime(PyObject *self, PyObject *args) return NULL; } } +#elif defined(_AIX) + for(outbuf = wcschr(fmt, '%'); + outbuf != NULL; + outbuf = wcschr(outbuf+2, '%')) + { + /* Issue #19634: On AIX, wcsftime("y", (1899, 1, 1, 0, 0, 0, 0, 0, 0)) + returns "0/" instead of "99" */ + if (outbuf[1] == L'y' && buf.tm_year < 0) { + PyErr_SetString(PyExc_ValueError, + "format %y requires year >= 1900 on AIX"); + Py_DECREF(format); + return NULL; + } + } #endif fmtlen = time_strlen(fmt);