summaryrefslogtreecommitdiff
path: root/Lib/test/test_getargs.py
diff options
context:
space:
mode:
authorJeremy Hylton <jeremy@alum.mit.edu>2001-09-10 01:57:12 +0000
committerJeremy Hylton <jeremy@alum.mit.edu>2001-09-10 01:57:12 +0000
commit9616e572537fd469a5fd448287fc58e558217f3c (patch)
treeea1cfe10d726004ab4a865425df95b87ee24141a /Lib/test/test_getargs.py
parentd58bc30748ab7fd39ab5541e93a47af30a3dfe90 (diff)
downloadcpython-9616e572537fd469a5fd448287fc58e558217f3c.tar.gz
Test the failed-unicode-decoding bug in PyArg_ParseTuple().
Diffstat (limited to 'Lib/test/test_getargs.py')
-rw-r--r--Lib/test/test_getargs.py24
1 files changed, 24 insertions, 0 deletions
diff --git a/Lib/test/test_getargs.py b/Lib/test/test_getargs.py
new file mode 100644
index 0000000000..574726109d
--- /dev/null
+++ b/Lib/test/test_getargs.py
@@ -0,0 +1,24 @@
+"""Test the internal getargs.c implementation
+
+ PyArg_ParseTuple() is defined here.
+
+The test here is not intended to test all of the module, just the
+single case that failed between 2.1 and 2.2a2.
+"""
+
+# marshal.loads() uses PyArg_ParseTuple(args, "s#:loads")
+# The s code will cause a Unicode conversion to occur. This test
+# verify that the error is propagated properly from the C code back to
+# Python.
+
+# XXX If the encoding succeeds using the current default encoding,
+# this test will fail because it does not test the right part of the
+# PyArg_ParseTuple() implementation.
+import marshal
+try:
+ marshal.loads(u"\222")
+except UnicodeError:
+ pass
+
+
+