diff options
author | Mark Dickinson <dickinsm@gmail.com> | 2009-12-20 16:03:30 (GMT) |
---|---|---|
committer | Mark Dickinson <dickinsm@gmail.com> | 2009-12-20 16:03:30 (GMT) |
commit | 1554b18b5aad4547574f680761da047d356b30b4 (patch) | |
tree | 9d235981894216d6f0d2e00bebd27e33c6274831 | |
parent | 808ff2c9d17a3d4ac94e49948a6f15bcf810282d (diff) | |
download | cpython-1554b18b5aad4547574f680761da047d356b30b4.zip cpython-1554b18b5aad4547574f680761da047d356b30b4.tar.gz cpython-1554b18b5aad4547574f680761da047d356b30b4.tar.bz2 |
Merged revisions 76930 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk
........
r76930 | mark.dickinson | 2009-12-20 15:57:56 +0000 (Sun, 20 Dec 2009) | 1 line
Add missing tests for PyArg_Parse* with format 'h'
........
-rw-r--r-- | Lib/test/test_getargs2.py | 17 | ||||
-rw-r--r-- | Modules/_testcapimodule.c | 10 |
2 files changed, 26 insertions, 1 deletions
diff --git a/Lib/test/test_getargs2.py b/Lib/test/test_getargs2.py index ee01018..108159c 100644 --- a/Lib/test/test_getargs2.py +++ b/Lib/test/test_getargs2.py @@ -48,7 +48,8 @@ LARGE = 0x7FFFFFFF VERY_LARGE = 0xFF0000121212121212121242 from _testcapi import UCHAR_MAX, USHRT_MAX, UINT_MAX, ULONG_MAX, INT_MAX, \ - INT_MIN, LONG_MIN, LONG_MAX, PY_SSIZE_T_MIN, PY_SSIZE_T_MAX + INT_MIN, LONG_MIN, LONG_MAX, PY_SSIZE_T_MIN, PY_SSIZE_T_MAX, \ + SHRT_MIN, SHRT_MAX # fake, they are not defined in Python's header files LLONG_MAX = 2**63-1 @@ -135,6 +136,20 @@ class Unsigned_TestCase(unittest.TestCase): self.assertEqual(VERY_LARGE & ULONG_MAX, getargs_k(VERY_LARGE)) class Signed_TestCase(unittest.TestCase): + def test_h(self): + from _testcapi import getargs_h + # h returns 'short', and does range checking (SHRT_MIN ... SHRT_MAX) + self.assertRaises(TypeError, getargs_h, 3.14) + self.assertEqual(99, getargs_h(Int())) + + self.assertRaises(OverflowError, getargs_h, SHRT_MIN-1) + self.assertEqual(SHRT_MIN, getargs_h(SHRT_MIN)) + self.assertEqual(SHRT_MAX, getargs_h(SHRT_MAX)) + self.assertRaises(OverflowError, getargs_h, SHRT_MAX+1) + + self.assertEqual(42, getargs_h(42)) + self.assertRaises(OverflowError, getargs_h, VERY_LARGE) + def test_i(self): from _testcapi import getargs_i # i returns 'int', and does range checking (INT_MIN ... INT_MAX) diff --git a/Modules/_testcapimodule.c b/Modules/_testcapimodule.c index 6244f3f..70da707 100644 --- a/Modules/_testcapimodule.c +++ b/Modules/_testcapimodule.c @@ -455,6 +455,15 @@ getargs_B(PyObject *self, PyObject *args) } static PyObject * +getargs_h(PyObject *self, PyObject *args) +{ + short value; + if (!PyArg_ParseTuple(args, "h", &value)) + return NULL; + return PyLong_FromLong((long)value); +} + +static PyObject * getargs_H(PyObject *self, PyObject *args) { unsigned short value; @@ -1566,6 +1575,7 @@ static PyMethodDef TestMethods[] = { METH_VARARGS|METH_KEYWORDS}, {"getargs_b", getargs_b, METH_VARARGS}, {"getargs_B", getargs_B, METH_VARARGS}, + {"getargs_h", getargs_h, METH_VARARGS}, {"getargs_H", getargs_H, METH_VARARGS}, {"getargs_I", getargs_I, METH_VARARGS}, {"getargs_k", getargs_k, METH_VARARGS}, |