js/src/tests/js1_8_1/strict/12.2.1.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/12.2.1.js	Wed Dec 31 06:09:35 2014 +0100
     1.3 @@ -0,0 +1,75 @@
     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 code, 'let' and 'const' declarations may not bind
    1.14 + * 'eval' or 'arguments'.
    1.15 + */
    1.16 +assertEq(testLenientAndStrict('let eval;',
    1.17 +                              parsesSuccessfully,
    1.18 +                              parseRaisesException(SyntaxError)),
    1.19 +         true);
    1.20 +assertEq(testLenientAndStrict('let x,eval;',
    1.21 +                              parsesSuccessfully,
    1.22 +                              parseRaisesException(SyntaxError)),
    1.23 +         true);
    1.24 +assertEq(testLenientAndStrict('let arguments;',
    1.25 +                              parsesSuccessfully,
    1.26 +                              parseRaisesException(SyntaxError)),
    1.27 +         true);
    1.28 +assertEq(testLenientAndStrict('let x,arguments;',
    1.29 +                              parsesSuccessfully,
    1.30 +                              parseRaisesException(SyntaxError)),
    1.31 +         true);
    1.32 +assertEq(testLenientAndStrict('const eval;',
    1.33 +                              parsesSuccessfully,
    1.34 +                              parseRaisesException(SyntaxError)),
    1.35 +         true);
    1.36 +assertEq(testLenientAndStrict('const x,eval;',
    1.37 +                              parsesSuccessfully,
    1.38 +                              parseRaisesException(SyntaxError)),
    1.39 +         true);
    1.40 +assertEq(testLenientAndStrict('const arguments;',
    1.41 +                              parsesSuccessfully,
    1.42 +                              parseRaisesException(SyntaxError)),
    1.43 +         true);
    1.44 +assertEq(testLenientAndStrict('const x,arguments;',
    1.45 +                              parsesSuccessfully,
    1.46 +                              parseRaisesException(SyntaxError)),
    1.47 +         true);
    1.48 +
    1.49 +/*
    1.50 + * In strict mode code, 'let' declarations appearing in 'for'
    1.51 + * or 'for in' statements may not bind 'eval' or 'arguments'.
    1.52 + */
    1.53 +assertEq(testLenientAndStrict('for (let eval in [])break;',
    1.54 +                              parsesSuccessfully,
    1.55 +                              parseRaisesException(SyntaxError)),
    1.56 +         true);
    1.57 +assertEq(testLenientAndStrict('for (let [eval] in [])break;',
    1.58 +                              parsesSuccessfully,
    1.59 +                              parseRaisesException(SyntaxError)),
    1.60 +         true);
    1.61 +assertEq(testLenientAndStrict('for (let {x:eval} in [])break;',
    1.62 +                              parsesSuccessfully,
    1.63 +                              parseRaisesException(SyntaxError)),
    1.64 +         true);
    1.65 +assertEq(testLenientAndStrict('for (let arguments in [])break;',
    1.66 +                              parsesSuccessfully,
    1.67 +                              parseRaisesException(SyntaxError)),
    1.68 +         true);
    1.69 +assertEq(testLenientAndStrict('for (let [arguments] in [])break;',
    1.70 +                              parsesSuccessfully,
    1.71 +                              parseRaisesException(SyntaxError)),
    1.72 +         true);
    1.73 +assertEq(testLenientAndStrict('for (let {x:arguments} in [])break;',
    1.74 +                              parsesSuccessfully,
    1.75 +                              parseRaisesException(SyntaxError)),
    1.76 +         true);
    1.77 +
    1.78 +reportCompare(true, true);

mercurial