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_opcodes.py | 121 +++++++++++++++++++++ 1 file changed, 121 insertions(+) create mode 100644 AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_opcodes.py (limited to 'AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_opcodes.py') diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_opcodes.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_opcodes.py new file mode 100644 index 0000000000..83873136fc --- /dev/null +++ b/AppPkg/Applications/Python/Python-2.7.2/Lib/test/test_opcodes.py @@ -0,0 +1,121 @@ +# Python test set -- part 2, opcodes + +from test.test_support import run_unittest, check_py3k_warnings +import unittest + +class OpcodeTest(unittest.TestCase): + + def test_try_inside_for_loop(self): + n = 0 + for i in range(10): + n = n+i + try: 1 // 0 + except NameError: pass + except ZeroDivisionError: pass + except TypeError: pass + try: pass + except: pass + try: pass + finally: pass + n = n+i + if n != 90: + self.fail('try inside for') + + def test_raise_class_exceptions(self): + + class AClass: pass + class BClass(AClass): pass + class CClass: pass + class DClass(AClass): + def __init__(self, ignore): + pass + + try: raise AClass() + except: pass + + try: raise AClass() + except AClass: pass + + try: raise BClass() + except AClass: pass + + try: raise BClass() + except CClass: self.fail() + except: pass + + a = AClass() + b = BClass() + + try: raise AClass, b + except BClass, v: + self.assertEqual(v, b) + else: self.fail("no exception") + + try: raise b + except AClass, v: + self.assertEqual(v, b) + else: + self.fail("no exception") + + # not enough arguments + try: raise BClass, a + except TypeError: pass + else: self.fail("no exception") + + try: raise DClass, a + except DClass, v: + self.assertIsInstance(v, DClass) + else: + self.fail("no exception") + + def test_compare_function_objects(self): + + f = eval('lambda: None') + g = eval('lambda: None') + self.assertNotEqual(f, g) + + f = eval('lambda a: a') + g = eval('lambda a: a') + self.assertNotEqual(f, g) + + f = eval('lambda a=1: a') + g = eval('lambda a=1: a') + self.assertNotEqual(f, g) + + f = eval('lambda: 0') + g = eval('lambda: 1') + self.assertNotEqual(f, g) + + f = eval('lambda: None') + g = eval('lambda a: None') + self.assertNotEqual(f, g) + + f = eval('lambda a: None') + g = eval('lambda b: None') + self.assertNotEqual(f, g) + + f = eval('lambda a: None') + g = eval('lambda a=None: None') + self.assertNotEqual(f, g) + + f = eval('lambda a=0: None') + g = eval('lambda a=1: None') + self.assertNotEqual(f, g) + + def test_modulo_of_string_subclasses(self): + class MyString(str): + def __mod__(self, value): + return 42 + self.assertEqual(MyString() % 3, 42) + + +def test_main(): + with check_py3k_warnings(("exceptions must derive from BaseException", + DeprecationWarning), + ("catching classes that don't inherit " + "from BaseException is not allowed", + DeprecationWarning)): + run_unittest(OpcodeTest) + +if __name__ == '__main__': + test_main() -- cgit v1.2.3