]> granicus.if.org Git - python/commitdiff
Merged revisions 76930 via svnmerge from
authorMark Dickinson <dickinsm@gmail.com>
Sun, 20 Dec 2009 16:03:30 +0000 (16:03 +0000)
committerMark Dickinson <dickinsm@gmail.com>
Sun, 20 Dec 2009 16:03:30 +0000 (16:03 +0000)
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'
........

Lib/test/test_getargs2.py
Modules/_testcapimodule.c

index ee01018b3e329bfebc75e9661d3ed3df89e4cb18..108159cd65c2619d1e162c6e26afc9d2699029ac 100644 (file)
@@ -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)
index 6244f3ff8290d09ef2818643e5ccdf90d5208cd5..70da707d4370aafdbb630ad187a66a8d4f2cee91 100644 (file)
@@ -454,6 +454,15 @@ getargs_B(PyObject *self, PyObject *args)
        return PyLong_FromUnsignedLong((unsigned long)value);
 }
 
+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)
 {
@@ -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},