summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2013-11-17 22:39:21 (GMT)
committerVictor Stinner <victor.stinner@gmail.com>2013-11-17 22:39:21 (GMT)
commit55329f8fbd7d4beb1483705f8a7bf1419e2eaba6 (patch)
tree9107ea9d0fb5cfa8c39f9ea433a31d5a423dadde
parentb6e622d184604771088b5d2dd4f4cf0cddb2a3ae (diff)
downloadcpython-55329f8fbd7d4beb1483705f8a7bf1419e2eaba6.zip
cpython-55329f8fbd7d4beb1483705f8a7bf1419e2eaba6.tar.gz
cpython-55329f8fbd7d4beb1483705f8a7bf1419e2eaba6.tar.bz2
Issue #19634: time.strftime("%y") now raises a ValueError on AIX when given a
year before 1900.
-rw-r--r--Lib/test/test_strftime.py16
-rw-r--r--Misc/NEWS3
-rw-r--r--Modules/timemodule.c14
3 files changed, 24 insertions, 9 deletions
diff --git a/Lib/test/test_strftime.py b/Lib/test/test_strftime.py
index 61215a1..ff6274e 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 58c3033..74f5819 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 2e48007..32fe6a7 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);