js/src/tests/js1_8_1/strict/generator-eval-arguments.js

changeset 0
6474c204b198
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/js/src/tests/js1_8_1/strict/generator-eval-arguments.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,38 @@
     1.4 +// |reftest| skip-if(Android)
     1.5 +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
     1.6 +
     1.7 +/*
     1.8 + * Any copyright is dedicated to the Public Domain.
     1.9 + * http://creativecommons.org/licenses/publicdomain/
    1.10 + */
    1.11 +
    1.12 +/*
    1.13 + * In strict mode, generator expressions may not locally bind 'eval'
    1.14 + * or 'arguments.'
    1.15 + */
    1.16 +assertEq(testLenientAndStrict('(1 for (eval in []))',
    1.17 +                              parsesSuccessfully,
    1.18 +                              parseRaisesException(SyntaxError)),
    1.19 +         true);
    1.20 +assertEq(testLenientAndStrict('(1 for ([eval] in []))',
    1.21 +                              parsesSuccessfully,
    1.22 +                              parseRaisesException(SyntaxError)),
    1.23 +         true);
    1.24 +assertEq(testLenientAndStrict('(1 for ({x:eval} in []))',
    1.25 +                              parsesSuccessfully,
    1.26 +                              parseRaisesException(SyntaxError)),
    1.27 +         true);
    1.28 +assertEq(testLenientAndStrict('(1 for (arguments in []))',
    1.29 +                              parsesSuccessfully,
    1.30 +                              parseRaisesException(SyntaxError)),
    1.31 +         true);
    1.32 +assertEq(testLenientAndStrict('(1 for ([arguments] in []))',
    1.33 +                              parsesSuccessfully,
    1.34 +                              parseRaisesException(SyntaxError)),
    1.35 +         true);
    1.36 +assertEq(testLenientAndStrict('(1 for ({x:arguments} in []))',
    1.37 +                              parsesSuccessfully,
    1.38 +                              parseRaisesException(SyntaxError)),
    1.39 +         true);
    1.40 +
    1.41 +reportCompare(true, true);

mercurial