From 4710c53dcad1ebf3755f3efb9e80ac24bd72a9b2 Mon Sep 17 00:00:00 2001 From: darylm503 Date: Mon, 16 Apr 2012 22:12:42 +0000 Subject: AppPkg/Applications/Python: Add Python 2.7.2 sources since the release of Python 2.7.3 made them unavailable from the python.org web site. These files are a subset of the python-2.7.2.tgz distribution from python.org. Changed files from PyMod-2.7.2 have been copied into the corresponding directories of this tree, replacing the original files in the distribution. Signed-off-by: daryl.mcdaniel@intel.com git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13197 6f19259b-4bc3-4df7-8a09-765794883524 --- .../Python/Python-2.7.2/Lib/test/test_unpack.py | 130 +++++++++++++++++++++ 1 file changed, 130 insertions(+) create mode 100644 AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_unpack.py (limited to 'AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_unpack.py') diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_unpack.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_unpack.py new file mode 100644 index 0000000000..5dc69a9092 --- /dev/null +++ b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_unpack.py @@ -0,0 +1,130 @@ +doctests = """ + +Unpack tuple + + >>> t = (1, 2, 3) + >>> a, b, c = t + >>> a == 1 and b == 2 and c == 3 + True + +Unpack list + + >>> l = [4, 5, 6] + >>> a, b, c = l + >>> a == 4 and b == 5 and c == 6 + True + +Unpack implied tuple + + >>> a, b, c = 7, 8, 9 + >>> a == 7 and b == 8 and c == 9 + True + +Unpack string... fun! + + >>> a, b, c = 'one' + >>> a == 'o' and b == 'n' and c == 'e' + True + +Unpack generic sequence + + >>> class Seq: + ... def __getitem__(self, i): + ... if i >= 0 and i < 3: return i + ... raise IndexError + ... + >>> a, b, c = Seq() + >>> a == 0 and b == 1 and c == 2 + True + +Single element unpacking, with extra syntax + + >>> st = (99,) + >>> sl = [100] + >>> a, = st + >>> a + 99 + >>> b, = sl + >>> b + 100 + +Now for some failures + +Unpacking non-sequence + + >>> a, b, c = 7 + Traceback (most recent call last): + ... + TypeError: 'int' object is not iterable + +Unpacking tuple of wrong size + + >>> a, b = t + Traceback (most recent call last): + ... + ValueError: too many values to unpack + +Unpacking tuple of wrong size + + >>> a, b = l + Traceback (most recent call last): + ... + ValueError: too many values to unpack + +Unpacking sequence too short + + >>> a, b, c, d = Seq() + Traceback (most recent call last): + ... + ValueError: need more than 3 values to unpack + +Unpacking sequence too long + + >>> a, b = Seq() + Traceback (most recent call last): + ... + ValueError: too many values to unpack + +Unpacking a sequence where the test for too long raises a different kind of +error + + >>> class BozoError(Exception): + ... pass + ... + >>> class BadSeq: + ... def __getitem__(self, i): + ... if i >= 0 and i < 3: + ... return i + ... elif i == 3: + ... raise BozoError + ... else: + ... raise IndexError + ... + +Trigger code while not expecting an IndexError (unpack sequence too long, wrong +error) + + >>> a, b, c, d, e = BadSeq() + Traceback (most recent call last): + ... + BozoError + +Trigger code while expecting an IndexError (unpack sequence too short, wrong +error) + + >>> a, b, c = BadSeq() + Traceback (most recent call last): + ... + BozoError + +""" + +__test__ = {'doctests' : doctests} + +def test_main(verbose=False): + from test import test_support + from test import test_unpack + test_support.run_doctest(test_unpack, verbose) + +if __name__ == "__main__": + test_main(verbose=True) -- cgit v1.2.3