summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/language/module-code/invalid-private-names-call-expression-bad-reference.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/language/module-code/invalid-private-names-call-expression-bad-reference.js')
-rw-r--r--js/src/tests/test262/language/module-code/invalid-private-names-call-expression-bad-reference.js41
1 files changed, 41 insertions, 0 deletions
diff --git a/js/src/tests/test262/language/module-code/invalid-private-names-call-expression-bad-reference.js b/js/src/tests/test262/language/module-code/invalid-private-names-call-expression-bad-reference.js
new file mode 100644
index 0000000000..47c5f99654
--- /dev/null
+++ b/js/src/tests/test262/language/module-code/invalid-private-names-call-expression-bad-reference.js
@@ -0,0 +1,41 @@
+// |reftest| shell-option(--enable-private-fields) skip-if(!xulRuntime.shell) error:SyntaxError module -- requires shell-options
+// This file was procedurally generated from the following sources:
+// - src/invalid-private-names/call-expression-bad-reference.case
+// - src/invalid-private-names/default/top-level-modulebody.template
+/*---
+description: bad reference in call expression (Invalid private names should throw a SyntaxError, top level of module body)
+esid: sec-static-semantics-early-errors
+features: [class-fields-private]
+flags: [generated, module]
+negative:
+ phase: parse
+ type: SyntaxError
+info: |
+ 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.
+
+ ModuleBody:ModuleItemList
+ It is a Syntax Error if AllPrivateNamesValid of ModuleItemList with an empty List
+ as an argument is false.
+
+
+ Static Semantics: AllPrivateNamesValid
+
+ MemberExpression : MemberExpression . PrivateName
+
+ 1. If StringValue of PrivateName is in names, return true.
+ 2. Return false.
+
+ CallExpression : CallExpression . PrivateName
+
+ 1. If StringValue of PrivateName is in names, return true.
+ 2. Return false.
+
+---*/
+
+
+$DONOTEVALUATE();
+
+(() => {})().#x