self.assertNotEqual(Point3D(1, 2, 3), (1, 2, 3))
# Make sure we can't unpack
- with self.assertRaisesRegex(TypeError, 'is not iterable'):
+ with self.assertRaisesRegex(TypeError, 'unpack'):
x, y, z = Point3D(4, 5, 6)
# Maka sure another class with the same field names isn't
>>> a, b, c = 7
Traceback (most recent call last):
...
- TypeError: 'int' object is not iterable
+ TypeError: cannot unpack non-iterable int object
Unpacking tuple of wrong size
>>> () = 42
Traceback (most recent call last):
...
- TypeError: 'int' object is not iterable
+ TypeError: cannot unpack non-iterable int object
Unpacking to an empty iterable should raise ValueError
>>> a, *b = 7
Traceback (most recent call last):
...
- TypeError: 'int' object is not iterable
+ TypeError: cannot unpack non-iterable int object
Unpacking sequence too short
--- /dev/null
+The error message of a TypeError raised when unpack non-iterable is now more
+specific.
assert(v != NULL);
it = PyObject_GetIter(v);
- if (it == NULL)
- goto Error;
+ if (it == NULL) {
+ if (PyErr_ExceptionMatches(PyExc_TypeError) &&
+ v->ob_type->tp_iter == NULL && !PySequence_Check(v))
+ {
+ PyErr_Format(PyExc_TypeError,
+ "cannot unpack non-iterable %.200s object",
+ v->ob_type->tp_name);
+ }
+ return 0;
+ }
for (; i < argcnt; i++) {
w = PyIter_Next(it);