summaryrefslogtreecommitdiffstats
path: root/js/src/tests/test262/language/expressions/super/call-spread-err-sngl-err-itr-step.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/test262/language/expressions/super/call-spread-err-sngl-err-itr-step.js')
-rw-r--r--js/src/tests/test262/language/expressions/super/call-spread-err-sngl-err-itr-step.js67
1 files changed, 67 insertions, 0 deletions
diff --git a/js/src/tests/test262/language/expressions/super/call-spread-err-sngl-err-itr-step.js b/js/src/tests/test262/language/expressions/super/call-spread-err-sngl-err-itr-step.js
new file mode 100644
index 0000000000..2c59552378
--- /dev/null
+++ b/js/src/tests/test262/language/expressions/super/call-spread-err-sngl-err-itr-step.js
@@ -0,0 +1,67 @@
+// This file was procedurally generated from the following sources:
+// - src/spread/sngl-err-itr-step.case
+// - src/spread/error/super-call.template
+/*---
+description: Spread operator applied to the only argument when IteratorStep fails (SuperCall)
+esid: sec-super-keyword-runtime-semantics-evaluation
+features: [Symbol.iterator]
+flags: [generated]
+info: |
+ SuperCall : super Arguments
+
+ 1. Let newTarget be GetNewTarget().
+ 2. If newTarget is undefined, throw a ReferenceError exception.
+ 3. Let func be GetSuperConstructor().
+ 4. ReturnIfAbrupt(func).
+ 5. Let argList be ArgumentListEvaluation of Arguments.
+ [...]
+
+ 12.3.6.1 Runtime Semantics: ArgumentListEvaluation
+
+ ArgumentList : ... AssignmentExpression
+
+ 1. Let list be an empty List.
+ 2. Let spreadRef be the result of evaluating AssignmentExpression.
+ 3. Let spreadObj be GetValue(spreadRef).
+ 4. Let iterator be GetIterator(spreadObj).
+ 5. ReturnIfAbrupt(iterator).
+ 6. Repeat
+ a. Let next be IteratorStep(iterator).
+ b. ReturnIfAbrupt(next).
+
+ 7.4.5 IteratorStep ( iterator )
+
+ 1. Let result be IteratorNext(iterator).
+ 2. ReturnIfAbrupt(result).
+
+ 7.4.2 IteratorNext ( iterator, value )
+
+ 1. If value was not passed, then
+ a. Let result be Invoke(iterator, "next", « »).
+ [...]
+ 3. ReturnIfAbrupt(result).
+---*/
+var iter = {};
+iter[Symbol.iterator] = function() {
+ return {
+ next: function() {
+ throw new Test262Error();
+ }
+ };
+};
+
+class Test262ParentClass {
+ constructor() {}
+}
+
+class Test262ChildClass extends Test262ParentClass {
+ constructor() {
+ super(...iter);
+ }
+}
+
+assert.throws(Test262Error, function() {
+ new Test262ChildClass();
+});
+
+reportCompare(0, 0);