diff options
| author | Guido van Rossum <guido@python.org> | 2007-05-15 18:46:22 +0000 | 
|---|---|---|
| committer | Guido van Rossum <guido@python.org> | 2007-05-15 18:46:22 +0000 | 
| commit | 1bc535dc7854b6be009a6bf3413a3a470e3fe749 (patch) | |
| tree | 7a43646468849a9ae624bd4314ff26b7b0e30f21 /Lib/test/test_grammar.py | |
| parent | 360e4b8fb19f34360093bc15ef9aad13115a6069 (diff) | |
| download | cpython-git-1bc535dc7854b6be009a6bf3413a3a470e3fe749.tar.gz | |
Merged revisions 55328-55341 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/branches/p3yk
........
  r55329 | brett.cannon | 2007-05-14 16:36:56 -0700 (Mon, 14 May 2007) | 3 lines
  Implement the removal of tuple parameter unpacking (PEP 3113).
  Thanks, Tony Lownds for the patch.
........
  r55331 | neal.norwitz | 2007-05-14 16:40:30 -0700 (Mon, 14 May 2007) | 1 line
  Update to use Python 3.0
........
  r55332 | brett.cannon | 2007-05-14 16:47:18 -0700 (Mon, 14 May 2007) | 2 lines
  Mention PEP 3113.  And thanks to Tony Lownds for the PEP 3113 patch.
........
  r55333 | neal.norwitz | 2007-05-14 16:57:06 -0700 (Mon, 14 May 2007) | 1 line
  Fix exception printing (no more exceptions module)
........
  r55334 | neal.norwitz | 2007-05-14 17:11:10 -0700 (Mon, 14 May 2007) | 1 line
  Remove popen* functions from os
........
  r55335 | neal.norwitz | 2007-05-14 18:03:38 -0700 (Mon, 14 May 2007) | 1 line
  Get rid of most of popen.  There are still some uses I need to cleanup.
........
  r55336 | neal.norwitz | 2007-05-14 21:11:34 -0700 (Mon, 14 May 2007) | 1 line
  Remove a few more remnants of the compiler package
........
  r55337 | neal.norwitz | 2007-05-14 22:28:27 -0700 (Mon, 14 May 2007) | 1 line
  Get test_[cx]pickle working on 64-bit platforms (avoid overflow int/long)
........
Diffstat (limited to 'Lib/test/test_grammar.py')
| -rw-r--r-- | Lib/test/test_grammar.py | 49 | 
1 files changed, 8 insertions, 41 deletions
| diff --git a/Lib/test/test_grammar.py b/Lib/test/test_grammar.py index 96cf824dc2..711d636f04 100644 --- a/Lib/test/test_grammar.py +++ b/Lib/test/test_grammar.py @@ -144,51 +144,32 @@ class GrammarTests(unittest.TestCase):          ### decorators: decorator+          ### parameters: '(' [typedargslist] ')'          ### typedargslist: ((tfpdef ['=' test] ',')* -        ###                ('*' [tname] (',' tname ['=' test])* [',' '**' tname] | '**' tname) +        ###                ('*' [tfpdef] (',' tfpdef ['=' test])* [',' '**' tfpdef] | '**' tfpdef)          ###                | tfpdef ['=' test] (',' tfpdef ['=' test])* [',']) -        ### tname: NAME [':' test] -        ### tfpdef: tname | '(' tfplist ')' -        ### tfplist: tfpdef (',' tfpdef)* [','] +        ### tfpdef: NAME [':' test]          ### varargslist: ((vfpdef ['=' test] ',')* -        ###              ('*' [vname] (',' vname ['=' test])*  [',' '**' vname] | '**' vname) +        ###              ('*' [vfpdef] (',' vfpdef ['=' test])*  [',' '**' vfpdef] | '**' vfpdef)          ###              | vfpdef ['=' test] (',' vfpdef ['=' test])* [',']) -        ### vname: NAME -        ### vfpdef: vname | '(' vfplist ')' -        ### vfplist: vfpdef (',' vfpdef)* [','] +        ### vfpdef: NAME          def f1(): pass          f1()          f1(*())          f1(*(), **{})          def f2(one_argument): pass          def f3(two, arguments): pass -        def f4(two, (compound, (argument, list))): pass -        def f5((compound, first), two): pass          self.assertEquals(f2.__code__.co_varnames, ('one_argument',))          self.assertEquals(f3.__code__.co_varnames, ('two', 'arguments')) -        if sys.platform.startswith('java'): -            self.assertEquals(f4.__code__.co_varnames, -                   ('two', '(compound, (argument, list))', 'compound', 'argument', -                                'list',)) -            self.assertEquals(f5.__code__.co_varnames, -                   ('(compound, first)', 'two', 'compound', 'first')) -        else: -            self.assertEquals(f4.__code__.co_varnames, -                  ('two', '.1', 'compound', 'argument',  'list')) -            self.assertEquals(f5.__code__.co_varnames, -                  ('.0', 'two', 'compound', 'first'))          def a1(one_arg,): pass          def a2(two, args,): pass          def v0(*rest): pass          def v1(a, *rest): pass          def v2(a, b, *rest): pass -        def v3(a, (b, c), *rest): return a, b, c, rest          f1()          f2(1)          f2(1,)          f3(1, 2)          f3(1, 2,) -        f4(1, (2, (3, 4)))          v0()          v0(1)          v0(1,) @@ -203,17 +184,7 @@ class GrammarTests(unittest.TestCase):          v2(1,2,3)          v2(1,2,3,4)          v2(1,2,3,4,5,6,7,8,9,0) -        v3(1,(2,3)) -        v3(1,(2,3),4) -        v3(1,(2,3),4,5,6,7,8,9,0) - -        # ceval unpacks the formal arguments into the first argcount names; -        # thus, the names nested inside tuples must appear after these names. -        if sys.platform.startswith('java'): -            self.assertEquals(v3.__code__.co_varnames, ('a', '(b, c)', 'rest', 'b', 'c')) -        else: -            self.assertEquals(v3.__code__.co_varnames, ('a', '.1', 'rest', 'b', 'c')) -        self.assertEquals(v3(1, (2, 3), 4), (1, 2, 3, (4,))) +          def d01(a=1): pass          d01()          d01(1) @@ -286,10 +257,6 @@ class GrammarTests(unittest.TestCase):          d22v(*(1, 2, 3, 4))          d22v(1, 2, *(3, 4, 5))          d22v(1, *(2, 3), **{'d': 4}) -        def d31v((x)): pass -        d31v(1) -        def d32v((x,)): pass -        d32v((1,))          # keyword only argument tests          def pos0key1(*, key): return key          pos0key1(key=100) @@ -312,12 +279,12 @@ class GrammarTests(unittest.TestCase):          self.assertEquals(f.__annotations__, {'x': float})          def f(x, y:1+2): pass          self.assertEquals(f.__annotations__, {'y': 3}) -        def f(a, (b:1, c:2, d)): pass +        def f(a, b:1, c:2, d): pass          self.assertEquals(f.__annotations__, {'b': 1, 'c': 2}) -        def f(a, (b:1, c:2, d), e:3=4, f=5, *g:6): pass +        def f(a, b:1, c:2, d, e:3=4, f=5, *g:6): pass          self.assertEquals(f.__annotations__,                            {'b': 1, 'c': 2, 'e': 3, 'g': 6}) -        def f(a, (b:1, c:2, d), e:3=4, f=5, *g:6, h:7, i=8, j:9=10, +        def f(a, b:1, c:2, d, e:3=4, f=5, *g:6, h:7, i=8, j:9=10,                **k:11) -> 12: pass          self.assertEquals(f.__annotations__,                            {'b': 1, 'c': 2, 'e': 3, 'g': 6, 'h': 7, 'j': 9, | 
