diff options
Diffstat (limited to 'js/src/tests/test262/language/statements/class/elements/privatename-not-valid-eval-earlyerr-6.js')
-rw-r--r-- | js/src/tests/test262/language/statements/class/elements/privatename-not-valid-eval-earlyerr-6.js | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/js/src/tests/test262/language/statements/class/elements/privatename-not-valid-eval-earlyerr-6.js b/js/src/tests/test262/language/statements/class/elements/privatename-not-valid-eval-earlyerr-6.js new file mode 100644 index 0000000000..54fa2cdc03 --- /dev/null +++ b/js/src/tests/test262/language/statements/class/elements/privatename-not-valid-eval-earlyerr-6.js @@ -0,0 +1,24 @@ +// Copyright (C) 2017 Valerie Young. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +esid: sec-scripts-static-semantics-early-errors +description: Early error when referencing privatename outside of class. +info: | + Static Semantics: Early Errors + ScriptBody : StatementList + + It is a Syntax Error if AllPrivateNamesValid of StatementList with an empty List as an argument is false unless the source code is eval code that is being processed by a direct eval. + +features: [class, class-fields-private] +---*/ + +var executed = false; +class C {} + +assert.throws(SyntaxError, function() { + eval("executed = true; new C().#x"); +}); + +assert.sameValue(executed, false); + +reportCompare(0, 0); |