summaryrefslogtreecommitdiffstats
path: root/Lib/test/test_struct.py
diff options
context:
space:
mode:
authorMark Dickinson <dickinsm@gmail.com>2010-04-04 08:52:51 (GMT)
committerMark Dickinson <dickinsm@gmail.com>2010-04-04 08:52:51 (GMT)
commite9493a1872b122097e6bd7660398c267b966d2f6 (patch)
tree879c21fe07539507838651ddc1f41113c0b2fa23 /Lib/test/test_struct.py
parent4c28ddc2f2356e19d10b11eb671ad934e6d07f8b (diff)
downloadcpython-e9493a1872b122097e6bd7660398c267b966d2f6.zip
cpython-e9493a1872b122097e6bd7660398c267b966d2f6.tar.gz
cpython-e9493a1872b122097e6bd7660398c267b966d2f6.tar.bz2
Merged revisions 79745 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r79745 | mark.dickinson | 2010-04-04 09:43:04 +0100 (Sun, 04 Apr 2010) | 3 lines Issue #8300 (__index__ handling in struct.pack): Remove redundant check and improve test coverage. Thanks Meador Inge for the patch. ........
Diffstat (limited to 'Lib/test/test_struct.py')
-rw-r--r--Lib/test/test_struct.py41
1 files changed, 31 insertions, 10 deletions
diff --git a/Lib/test/test_struct.py b/Lib/test/test_struct.py
index 2222562..0c8cd2c 100644
--- a/Lib/test/test_struct.py
+++ b/Lib/test/test_struct.py
@@ -269,6 +269,25 @@ class StructTest(unittest.TestCase):
def __int__(self):
return 42
+ # Objects with an '__index__' method should be allowed
+ # to pack as integers. That is assuming the implemented
+ # '__index__' method returns and 'int' or 'long'.
+ class Indexable(object):
+ def __init__(self, value):
+ self._value = value
+
+ def __index__(self):
+ return self._value
+
+ # If the '__index__' method raises a type error, then
+ # '__int__' should be used with a deprecation warning.
+ class BadIndex(object):
+ def __index__(self):
+ raise TypeError
+
+ def __int__(self):
+ return 42
+
self.assertRaises((TypeError, struct.error),
struct.pack, self.format,
"a string")
@@ -280,17 +299,12 @@ class StructTest(unittest.TestCase):
3+42j)
self.assertRaises((TypeError, struct.error),
struct.pack, self.format,
- NotAnInt)
-
- # Objects with an '__index__' method should be allowed
- # to pack as integers.
- class Indexable(object):
- def __init__(self, value):
- self._value = value
-
- def __index__(self):
- return self._value
+ NotAnInt())
+ self.assertRaises((TypeError, struct.error),
+ struct.pack, self.format,
+ BadIndex())
+ # Check for legitimate values from '__index__'.
for obj in (Indexable(0), Indexable(10), Indexable(17),
Indexable(42), Indexable(100), Indexable(127)):
try:
@@ -299,6 +313,13 @@ class StructTest(unittest.TestCase):
self.fail("integer code pack failed on object "
"with '__index__' method")
+ # Check for bogus values from '__index__'.
+ for obj in (Indexable(b'a'), Indexable('b'), Indexable(None),
+ Indexable({'a': 1}), Indexable([1, 2, 3])):
+ self.assertRaises((TypeError, struct.error),
+ struct.pack, self.format,
+ obj)
+
for code in integer_codes:
for byteorder in byteorders:
if (byteorder in ('', '@') and code in ('q', 'Q') and