mirror of
https://github.com/tc39/test262.git
synced 2025-05-10 18:00:27 +02:00
Early errors may result from parsing the source text of a test file, but they may also result from parsing some other source text as referenced through the ES2015 module syntax. The latter form of early error is not necessarily detectable by ECMAScript parsers, however. Because of this, the label "early" is not sufficiently precise for all Test262 consumers to correctly interpret all tests. Update the "phase" name of "early" to "parse" for all those negative tests that describe errors resulting from parsing of the file's source text directly. A forthcoming commit will update the remaining tests to use a "phase" name that is more specific to module resolution.
82 lines
2.7 KiB
JavaScript
82 lines
2.7 KiB
JavaScript
// This file was procedurally generated from the following sources:
|
|
// - src/dstr-binding/ary-ptrn-rest-not-final-ary.case
|
|
// - src/dstr-binding/default/cls-expr-meth-static-dflt.template
|
|
/*---
|
|
description: Rest element (array binding pattern) may not be followed by any element (static class expression method (default parameter))
|
|
esid: sec-class-definitions-runtime-semantics-evaluation
|
|
es6id: 14.5.16
|
|
features: [destructuring-binding, default-parameters]
|
|
flags: [generated]
|
|
negative:
|
|
phase: parse
|
|
type: SyntaxError
|
|
info: |
|
|
ClassExpression : class BindingIdentifieropt ClassTail
|
|
|
|
1. If BindingIdentifieropt is not present, let className be undefined.
|
|
2. Else, let className be StringValue of BindingIdentifier.
|
|
3. Let value be the result of ClassDefinitionEvaluation of ClassTail
|
|
with argument className.
|
|
[...]
|
|
|
|
14.5.14 Runtime Semantics: ClassDefinitionEvaluation
|
|
|
|
21. For each ClassElement m in order from methods
|
|
a. If IsStatic of m is false, then
|
|
b. Else,
|
|
Let status be the result of performing PropertyDefinitionEvaluation for
|
|
m with arguments F and false.
|
|
[...]
|
|
|
|
14.3.8 Runtime Semantics: DefineMethod
|
|
|
|
MethodDefinition : PropertyName ( StrictFormalParameters ) { FunctionBody }
|
|
|
|
[...]
|
|
6. Let closure be FunctionCreate(kind, StrictFormalParameters, FunctionBody,
|
|
scope, strict). If functionPrototype was passed as a parameter then pass its
|
|
value as the functionPrototype optional argument of FunctionCreate.
|
|
[...]
|
|
|
|
9.2.1 [[Call]] ( thisArgument, argumentsList)
|
|
|
|
[...]
|
|
7. Let result be OrdinaryCallEvaluateBody(F, argumentsList).
|
|
[...]
|
|
|
|
9.2.1.3 OrdinaryCallEvaluateBody ( F, argumentsList )
|
|
|
|
1. Let status be FunctionDeclarationInstantiation(F, argumentsList).
|
|
[...]
|
|
|
|
9.2.12 FunctionDeclarationInstantiation(func, argumentsList)
|
|
|
|
[...]
|
|
23. Let iteratorRecord be Record {[[iterator]]:
|
|
CreateListIterator(argumentsList), [[done]]: false}.
|
|
24. If hasDuplicates is true, then
|
|
[...]
|
|
25. Else,
|
|
b. Let formalStatus be IteratorBindingInitialization for formals with
|
|
iteratorRecord and env as arguments.
|
|
[...]
|
|
|
|
13.3.3 Destructuring Binding Patterns
|
|
ArrayBindingPattern[Yield] :
|
|
[ Elisionopt BindingRestElement[?Yield]opt ]
|
|
[ BindingElementList[?Yield] ]
|
|
[ BindingElementList[?Yield] , Elisionopt BindingRestElement[?Yield]opt ]
|
|
---*/
|
|
throw "Test262: This statement should not be evaluated.";
|
|
|
|
var callCount = 0;
|
|
var C = class {
|
|
static method([...[x], y] = [1, 2, 3]) {
|
|
|
|
callCount = callCount + 1;
|
|
}
|
|
};
|
|
|
|
C.method();
|
|
assert.sameValue(callCount, 1, 'method invoked exactly once');
|