1doctests = """
2
3Unpack tuple
4
5    >>> t = (1, 2, 3)
6    >>> a, b, c = t
7    >>> a == 1 and b == 2 and c == 3
8    True
9
10Unpack list
11
12    >>> l = [4, 5, 6]
13    >>> a, b, c = l
14    >>> a == 4 and b == 5 and c == 6
15    True
16
17Unpack implied tuple
18
19    >>> a, b, c = 7, 8, 9
20    >>> a == 7 and b == 8 and c == 9
21    True
22
23Unpack string... fun!
24
25    >>> a, b, c = 'one'
26    >>> a == 'o' and b == 'n' and c == 'e'
27    True
28
29Unpack generic sequence
30
31    >>> class Seq:
32    ...     def __getitem__(self, i):
33    ...         if i >= 0 and i < 3: return i
34    ...         raise IndexError
35    ...
36    >>> a, b, c = Seq()
37    >>> a == 0 and b == 1 and c == 2
38    True
39
40Single element unpacking, with extra syntax
41
42    >>> st = (99,)
43    >>> sl = [100]
44    >>> a, = st
45    >>> a
46    99
47    >>> b, = sl
48    >>> b
49    100
50
51Now for some failures
52
53Unpacking non-sequence
54
55    >>> a, b, c = 7
56    Traceback (most recent call last):
57      ...
58    TypeError: cannot unpack non-iterable int object
59
60Unpacking tuple of wrong size
61
62    >>> a, b = t
63    Traceback (most recent call last):
64      ...
65    ValueError: too many values to unpack (expected 2)
66
67Unpacking tuple of wrong size
68
69    >>> a, b = l
70    Traceback (most recent call last):
71      ...
72    ValueError: too many values to unpack (expected 2)
73
74Unpacking sequence too short
75
76    >>> a, b, c, d = Seq()
77    Traceback (most recent call last):
78      ...
79    ValueError: not enough values to unpack (expected 4, got 3)
80
81Unpacking sequence too long
82
83    >>> a, b = Seq()
84    Traceback (most recent call last):
85      ...
86    ValueError: too many values to unpack (expected 2)
87
88Unpacking a sequence where the test for too long raises a different kind of
89error
90
91    >>> class BozoError(Exception):
92    ...     pass
93    ...
94    >>> class BadSeq:
95    ...     def __getitem__(self, i):
96    ...         if i >= 0 and i < 3:
97    ...             return i
98    ...         elif i == 3:
99    ...             raise BozoError
100    ...         else:
101    ...             raise IndexError
102    ...
103
104Trigger code while not expecting an IndexError (unpack sequence too long, wrong
105error)
106
107    >>> a, b, c, d, e = BadSeq()
108    Traceback (most recent call last):
109      ...
110    test.test_unpack.BozoError
111
112Trigger code while expecting an IndexError (unpack sequence too short, wrong
113error)
114
115    >>> a, b, c = BadSeq()
116    Traceback (most recent call last):
117      ...
118    test.test_unpack.BozoError
119
120Allow unpacking empty iterables
121
122    >>> () = []
123    >>> [] = ()
124    >>> [] = []
125    >>> () = ()
126
127Unpacking non-iterables should raise TypeError
128
129    >>> () = 42
130    Traceback (most recent call last):
131      ...
132    TypeError: cannot unpack non-iterable int object
133
134Unpacking to an empty iterable should raise ValueError
135
136    >>> () = [42]
137    Traceback (most recent call last):
138      ...
139    ValueError: too many values to unpack (expected 0)
140
141"""
142
143__test__ = {'doctests' : doctests}
144
145def test_main(verbose=False):
146    from test import support
147    from test import test_unpack
148    support.run_doctest(test_unpack, verbose)
149
150if __name__ == "__main__":
151    test_main(verbose=True)
152