]> git.proxmox.com Git - mirror_edk2.git/blobdiff - AppPkg/Applications/Python/Python-2.7.2/Lib/lib2to3/tests/data/py2_test_grammar.py
edk2: Remove AppPkg, StdLib, StdLibPrivateInternalFiles
[mirror_edk2.git] / AppPkg / Applications / Python / Python-2.7.2 / Lib / lib2to3 / tests / data / py2_test_grammar.py
diff --git a/AppPkg/Applications/Python/Python-2.7.2/Lib/lib2to3/tests/data/py2_test_grammar.py b/AppPkg/Applications/Python/Python-2.7.2/Lib/lib2to3/tests/data/py2_test_grammar.py
deleted file mode 100644 (file)
index 06f2ddb..0000000
+++ /dev/null
@@ -1,974 +0,0 @@
-# Python test set -- part 1, grammar.\r
-# This just tests whether the parser accepts them all.\r
-\r
-# NOTE: When you run this test as a script from the command line, you\r
-# get warnings about certain hex/oct constants.  Since those are\r
-# issued by the parser, you can't suppress them by adding a\r
-# filterwarnings() call to this module.  Therefore, to shut up the\r
-# regression test, the filterwarnings() call has been added to\r
-# regrtest.py.\r
-\r
-from test.test_support import run_unittest, check_syntax_error\r
-import unittest\r
-import sys\r
-# testing import *\r
-from sys import *\r
-\r
-class TokenTests(unittest.TestCase):\r
-\r
-    def testBackslash(self):\r
-        # Backslash means line continuation:\r
-        x = 1 \\r
-        + 1\r
-        self.assertEquals(x, 2, 'backslash for line continuation')\r
-\r
-        # Backslash does not means continuation in comments :\\r
-        x = 0\r
-        self.assertEquals(x, 0, 'backslash ending comment')\r
-\r
-    def testPlainIntegers(self):\r
-        self.assertEquals(0xff, 255)\r
-        self.assertEquals(0377, 255)\r
-        self.assertEquals(2147483647, 017777777777)\r
-        # "0x" is not a valid literal\r
-        self.assertRaises(SyntaxError, eval, "0x")\r
-        from sys import maxint\r
-        if maxint == 2147483647:\r
-            self.assertEquals(-2147483647-1, -020000000000)\r
-            # XXX -2147483648\r
-            self.assert_(037777777777 > 0)\r
-            self.assert_(0xffffffff > 0)\r
-            for s in '2147483648', '040000000000', '0x100000000':\r
-                try:\r
-                    x = eval(s)\r
-                except OverflowError:\r
-                    self.fail("OverflowError on huge integer literal %r" % s)\r
-        elif maxint == 9223372036854775807:\r
-            self.assertEquals(-9223372036854775807-1, -01000000000000000000000)\r
-            self.assert_(01777777777777777777777 > 0)\r
-            self.assert_(0xffffffffffffffff > 0)\r
-            for s in '9223372036854775808', '02000000000000000000000', \\r
-                     '0x10000000000000000':\r
-                try:\r
-                    x = eval(s)\r
-                except OverflowError:\r
-                    self.fail("OverflowError on huge integer literal %r" % s)\r
-        else:\r
-            self.fail('Weird maxint value %r' % maxint)\r
-\r
-    def testLongIntegers(self):\r
-        x = 0L\r
-        x = 0l\r
-        x = 0xffffffffffffffffL\r
-        x = 0xffffffffffffffffl\r
-        x = 077777777777777777L\r
-        x = 077777777777777777l\r
-        x = 123456789012345678901234567890L\r
-        x = 123456789012345678901234567890l\r
-\r
-    def testFloats(self):\r
-        x = 3.14\r
-        x = 314.\r
-        x = 0.314\r
-        # XXX x = 000.314\r
-        x = .314\r
-        x = 3e14\r
-        x = 3E14\r
-        x = 3e-14\r
-        x = 3e+14\r
-        x = 3.e14\r
-        x = .3e14\r
-        x = 3.1e4\r
-\r
-    def testStringLiterals(self):\r
-        x = ''; y = ""; self.assert_(len(x) == 0 and x == y)\r
-        x = '\''; y = "'"; self.assert_(len(x) == 1 and x == y and ord(x) == 39)\r
-        x = '"'; y = "\""; self.assert_(len(x) == 1 and x == y and ord(x) == 34)\r
-        x = "doesn't \"shrink\" does it"\r
-        y = 'doesn\'t "shrink" does it'\r
-        self.assert_(len(x) == 24 and x == y)\r
-        x = "does \"shrink\" doesn't it"\r
-        y = 'does "shrink" doesn\'t it'\r
-        self.assert_(len(x) == 24 and x == y)\r
-        x = """\r
-The "quick"\r
-brown fox\r
-jumps over\r
-the 'lazy' dog.\r
-"""\r
-        y = '\nThe "quick"\nbrown fox\njumps over\nthe \'lazy\' dog.\n'\r
-        self.assertEquals(x, y)\r
-        y = '''\r
-The "quick"\r
-brown fox\r
-jumps over\r
-the 'lazy' dog.\r
-'''\r
-        self.assertEquals(x, y)\r
-        y = "\n\\r
-The \"quick\"\n\\r
-brown fox\n\\r
-jumps over\n\\r
-the 'lazy' dog.\n\\r
-"\r
-        self.assertEquals(x, y)\r
-        y = '\n\\r
-The \"quick\"\n\\r
-brown fox\n\\r
-jumps over\n\\r
-the \'lazy\' dog.\n\\r
-'\r
-        self.assertEquals(x, y)\r
-\r
-\r
-class GrammarTests(unittest.TestCase):\r
-\r
-    # single_input: NEWLINE | simple_stmt | compound_stmt NEWLINE\r
-    # XXX can't test in a script -- this rule is only used when interactive\r
-\r
-    # file_input: (NEWLINE | stmt)* ENDMARKER\r
-    # Being tested as this very moment this very module\r
-\r
-    # expr_input: testlist NEWLINE\r
-    # XXX Hard to test -- used only in calls to input()\r
-\r
-    def testEvalInput(self):\r
-        # testlist ENDMARKER\r
-        x = eval('1, 0 or 1')\r
-\r
-    def testFuncdef(self):\r
-        ### 'def' NAME parameters ':' suite\r
-        ### parameters: '(' [varargslist] ')'\r
-        ### varargslist: (fpdef ['=' test] ',')* ('*' NAME [',' ('**'|'*' '*') NAME]\r
-        ###            | ('**'|'*' '*') NAME)\r
-        ###            | fpdef ['=' test] (',' fpdef ['=' test])* [',']\r
-        ### fpdef: NAME | '(' fplist ')'\r
-        ### fplist: fpdef (',' fpdef)* [',']\r
-        ### arglist: (argument ',')* (argument | *' test [',' '**' test] | '**' test)\r
-        ### argument: [test '='] test   # Really [keyword '='] test\r
-        def f1(): pass\r
-        f1()\r
-        f1(*())\r
-        f1(*(), **{})\r
-        def f2(one_argument): pass\r
-        def f3(two, arguments): pass\r
-        def f4(two, (compound, (argument, list))): pass\r
-        def f5((compound, first), two): pass\r
-        self.assertEquals(f2.func_code.co_varnames, ('one_argument',))\r
-        self.assertEquals(f3.func_code.co_varnames, ('two', 'arguments'))\r
-        if sys.platform.startswith('java'):\r
-            self.assertEquals(f4.func_code.co_varnames,\r
-                   ('two', '(compound, (argument, list))', 'compound', 'argument',\r
-                                'list',))\r
-            self.assertEquals(f5.func_code.co_varnames,\r
-                   ('(compound, first)', 'two', 'compound', 'first'))\r
-        else:\r
-            self.assertEquals(f4.func_code.co_varnames,\r
-                  ('two', '.1', 'compound', 'argument',  'list'))\r
-            self.assertEquals(f5.func_code.co_varnames,\r
-                  ('.0', 'two', 'compound', 'first'))\r
-        def a1(one_arg,): pass\r
-        def a2(two, args,): pass\r
-        def v0(*rest): pass\r
-        def v1(a, *rest): pass\r
-        def v2(a, b, *rest): pass\r
-        def v3(a, (b, c), *rest): return a, b, c, rest\r
-\r
-        f1()\r
-        f2(1)\r
-        f2(1,)\r
-        f3(1, 2)\r
-        f3(1, 2,)\r
-        f4(1, (2, (3, 4)))\r
-        v0()\r
-        v0(1)\r
-        v0(1,)\r
-        v0(1,2)\r
-        v0(1,2,3,4,5,6,7,8,9,0)\r
-        v1(1)\r
-        v1(1,)\r
-        v1(1,2)\r
-        v1(1,2,3)\r
-        v1(1,2,3,4,5,6,7,8,9,0)\r
-        v2(1,2)\r
-        v2(1,2,3)\r
-        v2(1,2,3,4)\r
-        v2(1,2,3,4,5,6,7,8,9,0)\r
-        v3(1,(2,3))\r
-        v3(1,(2,3),4)\r
-        v3(1,(2,3),4,5,6,7,8,9,0)\r
-\r
-        # ceval unpacks the formal arguments into the first argcount names;\r
-        # thus, the names nested inside tuples must appear after these names.\r
-        if sys.platform.startswith('java'):\r
-            self.assertEquals(v3.func_code.co_varnames, ('a', '(b, c)', 'rest', 'b', 'c'))\r
-        else:\r
-            self.assertEquals(v3.func_code.co_varnames, ('a', '.1', 'rest', 'b', 'c'))\r
-        self.assertEquals(v3(1, (2, 3), 4), (1, 2, 3, (4,)))\r
-        def d01(a=1): pass\r
-        d01()\r
-        d01(1)\r
-        d01(*(1,))\r
-        d01(**{'a':2})\r
-        def d11(a, b=1): pass\r
-        d11(1)\r
-        d11(1, 2)\r
-        d11(1, **{'b':2})\r
-        def d21(a, b, c=1): pass\r
-        d21(1, 2)\r
-        d21(1, 2, 3)\r
-        d21(*(1, 2, 3))\r
-        d21(1, *(2, 3))\r
-        d21(1, 2, *(3,))\r
-        d21(1, 2, **{'c':3})\r
-        def d02(a=1, b=2): pass\r
-        d02()\r
-        d02(1)\r
-        d02(1, 2)\r
-        d02(*(1, 2))\r
-        d02(1, *(2,))\r
-        d02(1, **{'b':2})\r
-        d02(**{'a': 1, 'b': 2})\r
-        def d12(a, b=1, c=2): pass\r
-        d12(1)\r
-        d12(1, 2)\r
-        d12(1, 2, 3)\r
-        def d22(a, b, c=1, d=2): pass\r
-        d22(1, 2)\r
-        d22(1, 2, 3)\r
-        d22(1, 2, 3, 4)\r
-        def d01v(a=1, *rest): pass\r
-        d01v()\r
-        d01v(1)\r
-        d01v(1, 2)\r
-        d01v(*(1, 2, 3, 4))\r
-        d01v(*(1,))\r
-        d01v(**{'a':2})\r
-        def d11v(a, b=1, *rest): pass\r
-        d11v(1)\r
-        d11v(1, 2)\r
-        d11v(1, 2, 3)\r
-        def d21v(a, b, c=1, *rest): pass\r
-        d21v(1, 2)\r
-        d21v(1, 2, 3)\r
-        d21v(1, 2, 3, 4)\r
-        d21v(*(1, 2, 3, 4))\r
-        d21v(1, 2, **{'c': 3})\r
-        def d02v(a=1, b=2, *rest): pass\r
-        d02v()\r
-        d02v(1)\r
-        d02v(1, 2)\r
-        d02v(1, 2, 3)\r
-        d02v(1, *(2, 3, 4))\r
-        d02v(**{'a': 1, 'b': 2})\r
-        def d12v(a, b=1, c=2, *rest): pass\r
-        d12v(1)\r
-        d12v(1, 2)\r
-        d12v(1, 2, 3)\r
-        d12v(1, 2, 3, 4)\r
-        d12v(*(1, 2, 3, 4))\r
-        d12v(1, 2, *(3, 4, 5))\r
-        d12v(1, *(2,), **{'c': 3})\r
-        def d22v(a, b, c=1, d=2, *rest): pass\r
-        d22v(1, 2)\r
-        d22v(1, 2, 3)\r
-        d22v(1, 2, 3, 4)\r
-        d22v(1, 2, 3, 4, 5)\r
-        d22v(*(1, 2, 3, 4))\r
-        d22v(1, 2, *(3, 4, 5))\r
-        d22v(1, *(2, 3), **{'d': 4})\r
-        def d31v((x)): pass\r
-        d31v(1)\r
-        def d32v((x,)): pass\r
-        d32v((1,))\r
-\r
-        # keyword arguments after *arglist\r
-        def f(*args, **kwargs):\r
-            return args, kwargs\r
-        self.assertEquals(f(1, x=2, *[3, 4], y=5), ((1, 3, 4),\r
-                                                    {'x':2, 'y':5}))\r
-        self.assertRaises(SyntaxError, eval, "f(1, *(2,3), 4)")\r
-        self.assertRaises(SyntaxError, eval, "f(1, x=2, *(3,4), x=5)")\r
-\r
-        # Check ast errors in *args and *kwargs\r
-        check_syntax_error(self, "f(*g(1=2))")\r
-        check_syntax_error(self, "f(**g(1=2))")\r
-\r
-    def testLambdef(self):\r
-        ### lambdef: 'lambda' [varargslist] ':' test\r
-        l1 = lambda : 0\r
-        self.assertEquals(l1(), 0)\r
-        l2 = lambda : a[d] # XXX just testing the expression\r
-        l3 = lambda : [2 < x for x in [-1, 3, 0L]]\r
-        self.assertEquals(l3(), [0, 1, 0])\r
-        l4 = lambda x = lambda y = lambda z=1 : z : y() : x()\r
-        self.assertEquals(l4(), 1)\r
-        l5 = lambda x, y, z=2: x + y + z\r
-        self.assertEquals(l5(1, 2), 5)\r
-        self.assertEquals(l5(1, 2, 3), 6)\r
-        check_syntax_error(self, "lambda x: x = 2")\r
-        check_syntax_error(self, "lambda (None,): None")\r
-\r
-    ### stmt: simple_stmt | compound_stmt\r
-    # Tested below\r
-\r
-    def testSimpleStmt(self):\r
-        ### simple_stmt: small_stmt (';' small_stmt)* [';']\r
-        x = 1; pass; del x\r
-        def foo():\r
-            # verify statements that end with semi-colons\r
-            x = 1; pass; del x;\r
-        foo()\r
-\r
-    ### small_stmt: expr_stmt | print_stmt  | pass_stmt | del_stmt | flow_stmt | import_stmt | global_stmt | access_stmt | exec_stmt\r
-    # Tested below\r
-\r
-    def testExprStmt(self):\r
-        # (exprlist '=')* exprlist\r
-        1\r
-        1, 2, 3\r
-        x = 1\r
-        x = 1, 2, 3\r
-        x = y = z = 1, 2, 3\r
-        x, y, z = 1, 2, 3\r
-        abc = a, b, c = x, y, z = xyz = 1, 2, (3, 4)\r
-\r
-        check_syntax_error(self, "x + 1 = 1")\r
-        check_syntax_error(self, "a + 1 = b + 2")\r
-\r
-    def testPrintStmt(self):\r
-        # 'print' (test ',')* [test]\r
-        import StringIO\r
-\r
-        # Can't test printing to real stdout without comparing output\r
-        # which is not available in unittest.\r
-        save_stdout = sys.stdout\r
-        sys.stdout = StringIO.StringIO()\r
-\r
-        print 1, 2, 3\r
-        print 1, 2, 3,\r
-        print\r
-        print 0 or 1, 0 or 1,\r
-        print 0 or 1\r
-\r
-        # 'print' '>>' test ','\r
-        print >> sys.stdout, 1, 2, 3\r
-        print >> sys.stdout, 1, 2, 3,\r
-        print >> sys.stdout\r
-        print >> sys.stdout, 0 or 1, 0 or 1,\r
-        print >> sys.stdout, 0 or 1\r
-\r
-        # test printing to an instance\r
-        class Gulp:\r
-            def write(self, msg): pass\r
-\r
-        gulp = Gulp()\r
-        print >> gulp, 1, 2, 3\r
-        print >> gulp, 1, 2, 3,\r
-        print >> gulp\r
-        print >> gulp, 0 or 1, 0 or 1,\r
-        print >> gulp, 0 or 1\r
-\r
-        # test print >> None\r
-        def driver():\r
-            oldstdout = sys.stdout\r
-            sys.stdout = Gulp()\r
-            try:\r
-                tellme(Gulp())\r
-                tellme()\r
-            finally:\r
-                sys.stdout = oldstdout\r
-\r
-        # we should see this once\r
-        def tellme(file=sys.stdout):\r
-            print >> file, 'hello world'\r
-\r
-        driver()\r
-\r
-        # we should not see this at all\r
-        def tellme(file=None):\r
-            print >> file, 'goodbye universe'\r
-\r
-        driver()\r
-\r
-        self.assertEqual(sys.stdout.getvalue(), '''\\r
-1 2 3\r
-1 2 3\r
-1 1 1\r
-1 2 3\r
-1 2 3\r
-1 1 1\r
-hello world\r
-''')\r
-        sys.stdout = save_stdout\r
-\r
-        # syntax errors\r
-        check_syntax_error(self, 'print ,')\r
-        check_syntax_error(self, 'print >> x,')\r
-\r
-    def testDelStmt(self):\r
-        # 'del' exprlist\r
-        abc = [1,2,3]\r
-        x, y, z = abc\r
-        xyz = x, y, z\r
-\r
-        del abc\r
-        del x, y, (z, xyz)\r
-\r
-    def testPassStmt(self):\r
-        # 'pass'\r
-        pass\r
-\r
-    # flow_stmt: break_stmt | continue_stmt | return_stmt | raise_stmt\r
-    # Tested below\r
-\r
-    def testBreakStmt(self):\r
-        # 'break'\r
-        while 1: break\r
-\r
-    def testContinueStmt(self):\r
-        # 'continue'\r
-        i = 1\r
-        while i: i = 0; continue\r
-\r
-        msg = ""\r
-        while not msg:\r
-            msg = "ok"\r
-            try:\r
-                continue\r
-                msg = "continue failed to continue inside try"\r
-            except:\r
-                msg = "continue inside try called except block"\r
-        if msg != "ok":\r
-            self.fail(msg)\r
-\r
-        msg = ""\r
-        while not msg:\r
-            msg = "finally block not called"\r
-            try:\r
-                continue\r
-            finally:\r
-                msg = "ok"\r
-        if msg != "ok":\r
-            self.fail(msg)\r
-\r
-    def test_break_continue_loop(self):\r
-        # This test warrants an explanation. It is a test specifically for SF bugs\r
-        # #463359 and #462937. The bug is that a 'break' statement executed or\r
-        # exception raised inside a try/except inside a loop, *after* a continue\r
-        # statement has been executed in that loop, will cause the wrong number of\r
-        # arguments to be popped off the stack and the instruction pointer reset to\r
-        # a very small number (usually 0.) Because of this, the following test\r
-        # *must* written as a function, and the tracking vars *must* be function\r
-        # arguments with default values. Otherwise, the test will loop and loop.\r
-\r
-        def test_inner(extra_burning_oil = 1, count=0):\r
-            big_hippo = 2\r
-            while big_hippo:\r
-                count += 1\r
-                try:\r
-                    if extra_burning_oil and big_hippo == 1:\r
-                        extra_burning_oil -= 1\r
-                        break\r
-                    big_hippo -= 1\r
-                    continue\r
-                except:\r
-                    raise\r
-            if count > 2 or big_hippo <> 1:\r
-                self.fail("continue then break in try/except in loop broken!")\r
-        test_inner()\r
-\r
-    def testReturn(self):\r
-        # 'return' [testlist]\r
-        def g1(): return\r
-        def g2(): return 1\r
-        g1()\r
-        x = g2()\r
-        check_syntax_error(self, "class foo:return 1")\r
-\r
-    def testYield(self):\r
-        check_syntax_error(self, "class foo:yield 1")\r
-\r
-    def testRaise(self):\r
-        # 'raise' test [',' test]\r
-        try: raise RuntimeError, 'just testing'\r
-        except RuntimeError: pass\r
-        try: raise KeyboardInterrupt\r
-        except KeyboardInterrupt: pass\r
-\r
-    def testImport(self):\r
-        # 'import' dotted_as_names\r
-        import sys\r
-        import time, sys\r
-        # 'from' dotted_name 'import' ('*' | '(' import_as_names ')' | import_as_names)\r
-        from time import time\r
-        from time import (time)\r
-        # not testable inside a function, but already done at top of the module\r
-        # from sys import *\r
-        from sys import path, argv\r
-        from sys import (path, argv)\r
-        from sys import (path, argv,)\r
-\r
-    def testGlobal(self):\r
-        # 'global' NAME (',' NAME)*\r
-        global a\r
-        global a, b\r
-        global one, two, three, four, five, six, seven, eight, nine, ten\r
-\r
-    def testExec(self):\r
-        # 'exec' expr ['in' expr [',' expr]]\r
-        z = None\r
-        del z\r
-        exec 'z=1+1\n'\r
-        if z != 2: self.fail('exec \'z=1+1\'\\n')\r
-        del z\r
-        exec 'z=1+1'\r
-        if z != 2: self.fail('exec \'z=1+1\'')\r
-        z = None\r
-        del z\r
-        import types\r
-        if hasattr(types, "UnicodeType"):\r
-            exec r"""if 1:\r
-            exec u'z=1+1\n'\r
-            if z != 2: self.fail('exec u\'z=1+1\'\\n')\r
-            del z\r
-            exec u'z=1+1'\r
-            if z != 2: self.fail('exec u\'z=1+1\'')"""\r
-        g = {}\r
-        exec 'z = 1' in g\r
-        if g.has_key('__builtins__'): del g['__builtins__']\r
-        if g != {'z': 1}: self.fail('exec \'z = 1\' in g')\r
-        g = {}\r
-        l = {}\r
-\r
-        import warnings\r
-        warnings.filterwarnings("ignore", "global statement", module="<string>")\r
-        exec 'global a; a = 1; b = 2' in g, l\r
-        if g.has_key('__builtins__'): del g['__builtins__']\r
-        if l.has_key('__builtins__'): del l['__builtins__']\r
-        if (g, l) != ({'a':1}, {'b':2}):\r
-            self.fail('exec ... in g (%s), l (%s)' %(g,l))\r
-\r
-    def testAssert(self):\r
-        # assert_stmt: 'assert' test [',' test]\r
-        assert 1\r
-        assert 1, 1\r
-        assert lambda x:x\r
-        assert 1, lambda x:x+1\r
-        try:\r
-            assert 0, "msg"\r
-        except AssertionError, e:\r
-            self.assertEquals(e.args[0], "msg")\r
-        else:\r
-            if __debug__:\r
-                self.fail("AssertionError not raised by assert 0")\r
-\r
-    ### compound_stmt: if_stmt | while_stmt | for_stmt | try_stmt | funcdef | classdef\r
-    # Tested below\r
-\r
-    def testIf(self):\r
-        # 'if' test ':' suite ('elif' test ':' suite)* ['else' ':' suite]\r
-        if 1: pass\r
-        if 1: pass\r
-        else: pass\r
-        if 0: pass\r
-        elif 0: pass\r
-        if 0: pass\r
-        elif 0: pass\r
-        elif 0: pass\r
-        elif 0: pass\r
-        else: pass\r
-\r
-    def testWhile(self):\r
-        # 'while' test ':' suite ['else' ':' suite]\r
-        while 0: pass\r
-        while 0: pass\r
-        else: pass\r
-\r
-        # Issue1920: "while 0" is optimized away,\r
-        # ensure that the "else" clause is still present.\r
-        x = 0\r
-        while 0:\r
-            x = 1\r
-        else:\r
-            x = 2\r
-        self.assertEquals(x, 2)\r
-\r
-    def testFor(self):\r
-        # 'for' exprlist 'in' exprlist ':' suite ['else' ':' suite]\r
-        for i in 1, 2, 3: pass\r
-        for i, j, k in (): pass\r
-        else: pass\r
-        class Squares:\r
-            def __init__(self, max):\r
-                self.max = max\r
-                self.sofar = []\r
-            def __len__(self): return len(self.sofar)\r
-            def __getitem__(self, i):\r
-                if not 0 <= i < self.max: raise IndexError\r
-                n = len(self.sofar)\r
-                while n <= i:\r
-                    self.sofar.append(n*n)\r
-                    n = n+1\r
-                return self.sofar[i]\r
-        n = 0\r
-        for x in Squares(10): n = n+x\r
-        if n != 285:\r
-            self.fail('for over growing sequence')\r
-\r
-        result = []\r
-        for x, in [(1,), (2,), (3,)]:\r
-            result.append(x)\r
-        self.assertEqual(result, [1, 2, 3])\r
-\r
-    def testTry(self):\r
-        ### try_stmt: 'try' ':' suite (except_clause ':' suite)+ ['else' ':' suite]\r
-        ###         | 'try' ':' suite 'finally' ':' suite\r
-        ### except_clause: 'except' [expr [('as' | ',') expr]]\r
-        try:\r
-            1/0\r
-        except ZeroDivisionError:\r
-            pass\r
-        else:\r
-            pass\r
-        try: 1/0\r
-        except EOFError: pass\r
-        except TypeError as msg: pass\r
-        except RuntimeError, msg: pass\r
-        except: pass\r
-        else: pass\r
-        try: 1/0\r
-        except (EOFError, TypeError, ZeroDivisionError): pass\r
-        try: 1/0\r
-        except (EOFError, TypeError, ZeroDivisionError), msg: pass\r
-        try: pass\r
-        finally: pass\r
-\r
-    def testSuite(self):\r
-        # simple_stmt | NEWLINE INDENT NEWLINE* (stmt NEWLINE*)+ DEDENT\r
-        if 1: pass\r
-        if 1:\r
-            pass\r
-        if 1:\r
-            #\r
-            #\r
-            #\r
-            pass\r
-            pass\r
-            #\r
-            pass\r
-            #\r
-\r
-    def testTest(self):\r
-        ### and_test ('or' and_test)*\r
-        ### and_test: not_test ('and' not_test)*\r
-        ### not_test: 'not' not_test | comparison\r
-        if not 1: pass\r
-        if 1 and 1: pass\r
-        if 1 or 1: pass\r
-        if not not not 1: pass\r
-        if not 1 and 1 and 1: pass\r
-        if 1 and 1 or 1 and 1 and 1 or not 1 and 1: pass\r
-\r
-    def testComparison(self):\r
-        ### comparison: expr (comp_op expr)*\r
-        ### comp_op: '<'|'>'|'=='|'>='|'<='|'<>'|'!='|'in'|'not' 'in'|'is'|'is' 'not'\r
-        if 1: pass\r
-        x = (1 == 1)\r
-        if 1 == 1: pass\r
-        if 1 != 1: pass\r
-        if 1 <> 1: pass\r
-        if 1 < 1: pass\r
-        if 1 > 1: pass\r
-        if 1 <= 1: pass\r
-        if 1 >= 1: pass\r
-        if 1 is 1: pass\r
-        if 1 is not 1: pass\r
-        if 1 in (): pass\r
-        if 1 not in (): pass\r
-        if 1 < 1 > 1 == 1 >= 1 <= 1 <> 1 != 1 in 1 not in 1 is 1 is not 1: pass\r
-\r
-    def testBinaryMaskOps(self):\r
-        x = 1 & 1\r
-        x = 1 ^ 1\r
-        x = 1 | 1\r
-\r
-    def testShiftOps(self):\r
-        x = 1 << 1\r
-        x = 1 >> 1\r
-        x = 1 << 1 >> 1\r
-\r
-    def testAdditiveOps(self):\r
-        x = 1\r
-        x = 1 + 1\r
-        x = 1 - 1 - 1\r
-        x = 1 - 1 + 1 - 1 + 1\r
-\r
-    def testMultiplicativeOps(self):\r
-        x = 1 * 1\r
-        x = 1 / 1\r
-        x = 1 % 1\r
-        x = 1 / 1 * 1 % 1\r
-\r
-    def testUnaryOps(self):\r
-        x = +1\r
-        x = -1\r
-        x = ~1\r
-        x = ~1 ^ 1 & 1 | 1 & 1 ^ -1\r
-        x = -1*1/1 + 1*1 - ---1*1\r
-\r
-    def testSelectors(self):\r
-        ### trailer: '(' [testlist] ')' | '[' subscript ']' | '.' NAME\r
-        ### subscript: expr | [expr] ':' [expr]\r
-\r
-        import sys, time\r
-        c = sys.path[0]\r
-        x = time.time()\r
-        x = sys.modules['time'].time()\r
-        a = '01234'\r
-        c = a[0]\r
-        c = a[-1]\r
-        s = a[0:5]\r
-        s = a[:5]\r
-        s = a[0:]\r
-        s = a[:]\r
-        s = a[-5:]\r
-        s = a[:-1]\r
-        s = a[-4:-3]\r
-        # A rough test of SF bug 1333982.  http://python.org/sf/1333982\r
-        # The testing here is fairly incomplete.\r
-        # Test cases should include: commas with 1 and 2 colons\r
-        d = {}\r
-        d[1] = 1\r
-        d[1,] = 2\r
-        d[1,2] = 3\r
-        d[1,2,3] = 4\r
-        L = list(d)\r
-        L.sort()\r
-        self.assertEquals(str(L), '[1, (1,), (1, 2), (1, 2, 3)]')\r
-\r
-    def testAtoms(self):\r
-        ### atom: '(' [testlist] ')' | '[' [testlist] ']' | '{' [dictmaker] '}' | '`' testlist '`' | NAME | NUMBER | STRING\r
-        ### dictmaker: test ':' test (',' test ':' test)* [',']\r
-\r
-        x = (1)\r
-        x = (1 or 2 or 3)\r
-        x = (1 or 2 or 3, 2, 3)\r
-\r
-        x = []\r
-        x = [1]\r
-        x = [1 or 2 or 3]\r
-        x = [1 or 2 or 3, 2, 3]\r
-        x = []\r
-\r
-        x = {}\r
-        x = {'one': 1}\r
-        x = {'one': 1,}\r
-        x = {'one' or 'two': 1 or 2}\r
-        x = {'one': 1, 'two': 2}\r
-        x = {'one': 1, 'two': 2,}\r
-        x = {'one': 1, 'two': 2, 'three': 3, 'four': 4, 'five': 5, 'six': 6}\r
-\r
-        x = `x`\r
-        x = `1 or 2 or 3`\r
-        self.assertEqual(`1,2`, '(1, 2)')\r
-\r
-        x = x\r
-        x = 'x'\r
-        x = 123\r
-\r
-    ### exprlist: expr (',' expr)* [',']\r
-    ### testlist: test (',' test)* [',']\r
-    # These have been exercised enough above\r
-\r
-    def testClassdef(self):\r
-        # 'class' NAME ['(' [testlist] ')'] ':' suite\r
-        class B: pass\r
-        class B2(): pass\r
-        class C1(B): pass\r
-        class C2(B): pass\r
-        class D(C1, C2, B): pass\r
-        class C:\r
-            def meth1(self): pass\r
-            def meth2(self, arg): pass\r
-            def meth3(self, a1, a2): pass\r
-        # decorator: '@' dotted_name [ '(' [arglist] ')' ] NEWLINE\r
-        # decorators: decorator+\r
-        # decorated: decorators (classdef | funcdef)\r
-        def class_decorator(x):\r
-            x.decorated = True\r
-            return x\r
-        @class_decorator\r
-        class G:\r
-            pass\r
-        self.assertEqual(G.decorated, True)\r
-\r
-    def testListcomps(self):\r
-        # list comprehension tests\r
-        nums = [1, 2, 3, 4, 5]\r
-        strs = ["Apple", "Banana", "Coconut"]\r
-        spcs = ["  Apple", " Banana ", "Coco  nut  "]\r
-\r
-        self.assertEqual([s.strip() for s in spcs], ['Apple', 'Banana', 'Coco  nut'])\r
-        self.assertEqual([3 * x for x in nums], [3, 6, 9, 12, 15])\r
-        self.assertEqual([x for x in nums if x > 2], [3, 4, 5])\r
-        self.assertEqual([(i, s) for i in nums for s in strs],\r
-                         [(1, 'Apple'), (1, 'Banana'), (1, 'Coconut'),\r
-                          (2, 'Apple'), (2, 'Banana'), (2, 'Coconut'),\r
-                          (3, 'Apple'), (3, 'Banana'), (3, 'Coconut'),\r
-                          (4, 'Apple'), (4, 'Banana'), (4, 'Coconut'),\r
-                          (5, 'Apple'), (5, 'Banana'), (5, 'Coconut')])\r
-        self.assertEqual([(i, s) for i in nums for s in [f for f in strs if "n" in f]],\r
-                         [(1, 'Banana'), (1, 'Coconut'), (2, 'Banana'), (2, 'Coconut'),\r
-                          (3, 'Banana'), (3, 'Coconut'), (4, 'Banana'), (4, 'Coconut'),\r
-                          (5, 'Banana'), (5, 'Coconut')])\r
-        self.assertEqual([(lambda a:[a**i for i in range(a+1)])(j) for j in range(5)],\r
-                         [[1], [1, 1], [1, 2, 4], [1, 3, 9, 27], [1, 4, 16, 64, 256]])\r
-\r
-        def test_in_func(l):\r
-            return [None < x < 3 for x in l if x > 2]\r
-\r
-        self.assertEqual(test_in_func(nums), [False, False, False])\r
-\r
-        def test_nested_front():\r
-            self.assertEqual([[y for y in [x, x + 1]] for x in [1,3,5]],\r
-                             [[1, 2], [3, 4], [5, 6]])\r
-\r
-        test_nested_front()\r
-\r
-        check_syntax_error(self, "[i, s for i in nums for s in strs]")\r
-        check_syntax_error(self, "[x if y]")\r
-\r
-        suppliers = [\r
-          (1, "Boeing"),\r
-          (2, "Ford"),\r
-          (3, "Macdonalds")\r
-        ]\r
-\r
-        parts = [\r
-          (10, "Airliner"),\r
-          (20, "Engine"),\r
-          (30, "Cheeseburger")\r
-        ]\r
-\r
-        suppart = [\r
-          (1, 10), (1, 20), (2, 20), (3, 30)\r
-        ]\r
-\r
-        x = [\r
-          (sname, pname)\r
-            for (sno, sname) in suppliers\r
-              for (pno, pname) in parts\r
-                for (sp_sno, sp_pno) in suppart\r
-                  if sno == sp_sno and pno == sp_pno\r
-        ]\r
-\r
-        self.assertEqual(x, [('Boeing', 'Airliner'), ('Boeing', 'Engine'), ('Ford', 'Engine'),\r
-                             ('Macdonalds', 'Cheeseburger')])\r
-\r
-    def testGenexps(self):\r
-        # generator expression tests\r
-        g = ([x for x in range(10)] for x in range(1))\r
-        self.assertEqual(g.next(), [x for x in range(10)])\r
-        try:\r
-            g.next()\r
-            self.fail('should produce StopIteration exception')\r
-        except StopIteration:\r
-            pass\r
-\r
-        a = 1\r
-        try:\r
-            g = (a for d in a)\r
-            g.next()\r
-            self.fail('should produce TypeError')\r
-        except TypeError:\r
-            pass\r
-\r
-        self.assertEqual(list((x, y) for x in 'abcd' for y in 'abcd'), [(x, y) for x in 'abcd' for y in 'abcd'])\r
-        self.assertEqual(list((x, y) for x in 'ab' for y in 'xy'), [(x, y) for x in 'ab' for y in 'xy'])\r
-\r
-        a = [x for x in range(10)]\r
-        b = (x for x in (y for y in a))\r
-        self.assertEqual(sum(b), sum([x for x in range(10)]))\r
-\r
-        self.assertEqual(sum(x**2 for x in range(10)), sum([x**2 for x in range(10)]))\r
-        self.assertEqual(sum(x*x for x in range(10) if x%2), sum([x*x for x in range(10) if x%2]))\r
-        self.assertEqual(sum(x for x in (y for y in range(10))), sum([x for x in range(10)]))\r
-        self.assertEqual(sum(x for x in (y for y in (z for z in range(10)))), sum([x for x in range(10)]))\r
-        self.assertEqual(sum(x for x in [y for y in (z for z in range(10))]), sum([x for x in range(10)]))\r
-        self.assertEqual(sum(x for x in (y for y in (z for z in range(10) if True)) if True), sum([x for x in range(10)]))\r
-        self.assertEqual(sum(x for x in (y for y in (z for z in range(10) if True) if False) if True), 0)\r
-        check_syntax_error(self, "foo(x for x in range(10), 100)")\r
-        check_syntax_error(self, "foo(100, x for x in range(10))")\r
-\r
-    def testComprehensionSpecials(self):\r
-        # test for outmost iterable precomputation\r
-        x = 10; g = (i for i in range(x)); x = 5\r
-        self.assertEqual(len(list(g)), 10)\r
-\r
-        # This should hold, since we're only precomputing outmost iterable.\r
-        x = 10; t = False; g = ((i,j) for i in range(x) if t for j in range(x))\r
-        x = 5; t = True;\r
-        self.assertEqual([(i,j) for i in range(10) for j in range(5)], list(g))\r
-\r
-        # Grammar allows multiple adjacent 'if's in listcomps and genexps,\r
-        # even though it's silly. Make sure it works (ifelse broke this.)\r
-        self.assertEqual([ x for x in range(10) if x % 2 if x % 3 ], [1, 5, 7])\r
-        self.assertEqual(list(x for x in range(10) if x % 2 if x % 3), [1, 5, 7])\r
-\r
-        # verify unpacking single element tuples in listcomp/genexp.\r
-        self.assertEqual([x for x, in [(4,), (5,), (6,)]], [4, 5, 6])\r
-        self.assertEqual(list(x for x, in [(7,), (8,), (9,)]), [7, 8, 9])\r
-\r
-    def test_with_statement(self):\r
-        class manager(object):\r
-            def __enter__(self):\r
-                return (1, 2)\r
-            def __exit__(self, *args):\r
-                pass\r
-\r
-        with manager():\r
-            pass\r
-        with manager() as x:\r
-            pass\r
-        with manager() as (x, y):\r
-            pass\r
-        with manager(), manager():\r
-            pass\r
-        with manager() as x, manager() as y:\r
-            pass\r
-        with manager() as x, manager():\r
-            pass\r
-\r
-    def testIfElseExpr(self):\r
-        # Test ifelse expressions in various cases\r
-        def _checkeval(msg, ret):\r
-            "helper to check that evaluation of expressions is done correctly"\r
-            print x\r
-            return ret\r
-\r
-        self.assertEqual([ x() for x in lambda: True, lambda: False if x() ], [True])\r
-        self.assertEqual([ x() for x in (lambda: True, lambda: False) if x() ], [True])\r
-        self.assertEqual([ x(False) for x in (lambda x: False if x else True, lambda x: True if x else False) if x(False) ], [True])\r
-        self.assertEqual((5 if 1 else _checkeval("check 1", 0)), 5)\r
-        self.assertEqual((_checkeval("check 2", 0) if 0 else 5), 5)\r
-        self.assertEqual((5 and 6 if 0 else 1), 1)\r
-        self.assertEqual(((5 and 6) if 0 else 1), 1)\r
-        self.assertEqual((5 and (6 if 1 else 1)), 6)\r
-        self.assertEqual((0 or _checkeval("check 3", 2) if 0 else 3), 3)\r
-        self.assertEqual((1 or _checkeval("check 4", 2) if 1 else _checkeval("check 5", 3)), 1)\r
-        self.assertEqual((0 or 5 if 1 else _checkeval("check 6", 3)), 5)\r
-        self.assertEqual((not 5 if 1 else 1), False)\r
-        self.assertEqual((not 5 if 0 else 1), 1)\r
-        self.assertEqual((6 + 1 if 1 else 2), 7)\r
-        self.assertEqual((6 - 1 if 1 else 2), 5)\r
-        self.assertEqual((6 * 2 if 1 else 4), 12)\r
-        self.assertEqual((6 / 2 if 1 else 3), 3)\r
-        self.assertEqual((6 < 4 if 0 else 2), 2)\r
-\r
-\r
-def test_main():\r
-    run_unittest(TokenTests, GrammarTests)\r
-\r
-if __name__ == '__main__':\r
-    test_main()\r