mirror of https://github.com/tc39/test262.git
Merge pull request #1185 from rwaldron/obj-rest-removal
Removes previously missed object rest `...{` cases.
This commit is contained in:
commit
626e823b46
|
@ -1,40 +0,0 @@
|
||||||
// Copyright (C) 2017 Caio Lima & the V8 project authors. All rights reserved.
|
|
||||||
// This code is governed by the BSD license found in the LICENSE file.
|
|
||||||
|
|
||||||
/*---
|
|
||||||
desc: >
|
|
||||||
When DestructuringAssignmentTarget is an object literal, it should be parsed
|
|
||||||
parsed as a DestructuringAssignmentPattern and evaluated as a destructuring
|
|
||||||
assignment and object rest desconstruction is allowed in that case.
|
|
||||||
template: default
|
|
||||||
esid: pending
|
|
||||||
includes: [propertyHelper.js]
|
|
||||||
features: [object-rest]
|
|
||||||
---*/
|
|
||||||
|
|
||||||
//- setup
|
|
||||||
let a, b, c, rest;
|
|
||||||
//- elems
|
|
||||||
{a, b, ...{c, ...rest}}
|
|
||||||
//- vals
|
|
||||||
{a: 1, b: 2, c: 3, d: 4, e: 5}
|
|
||||||
//- body
|
|
||||||
assert.sameValue(a, 1);
|
|
||||||
assert.sameValue(b, 2);
|
|
||||||
assert.sameValue(c, 3);
|
|
||||||
|
|
||||||
assert.sameValue(rest.d, 4);
|
|
||||||
assert.sameValue(rest.e, 5);
|
|
||||||
|
|
||||||
verifyEnumerable(rest, "d");
|
|
||||||
verifyWritable(rest, "d");
|
|
||||||
verifyConfigurable(rest, "d");
|
|
||||||
|
|
||||||
verifyEnumerable(rest, "e");
|
|
||||||
verifyWritable(rest, "e");
|
|
||||||
verifyConfigurable(rest, "e");
|
|
||||||
|
|
||||||
//- teardown
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,30 +0,0 @@
|
||||||
// Copyright (C) 2017 Caio Lima & the V8 project authors. All rights reserved.
|
|
||||||
// This code is governed by the BSD license found in the LICENSE file.
|
|
||||||
|
|
||||||
/*---
|
|
||||||
desc: >
|
|
||||||
When DestructuringAssignmentTarget is an object literal, it should be parsed
|
|
||||||
parsed as a DestructuringAssignmentPattern and evaluated as a destructuring
|
|
||||||
assignment.
|
|
||||||
template: default
|
|
||||||
esid: pending
|
|
||||||
features: [object-rest]
|
|
||||||
---*/
|
|
||||||
|
|
||||||
//- setup
|
|
||||||
let a, b, c, d, e;
|
|
||||||
//- elems
|
|
||||||
{a, b, ...{c, e}}
|
|
||||||
//- vals
|
|
||||||
{a: 1, b: 2, c: 3, d: 4, e: 5}
|
|
||||||
//- body
|
|
||||||
assert.sameValue(a, 1);
|
|
||||||
assert.sameValue(b, 2);
|
|
||||||
assert.sameValue(c, 3);
|
|
||||||
assert.sameValue(e, 5);
|
|
||||||
assert.sameValue(d, undefined);
|
|
||||||
|
|
||||||
//- teardown
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,29 +0,0 @@
|
||||||
// Copyright (C) 2017 Caio Lima & the V8 project authors. All rights reserved.
|
|
||||||
// This code is governed by the BSD license found in the LICENSE file.
|
|
||||||
|
|
||||||
/*---
|
|
||||||
desc: >
|
|
||||||
Rest object contains just source object's own properties
|
|
||||||
template: default
|
|
||||||
esid: pending
|
|
||||||
features: [object-rest]
|
|
||||||
---*/
|
|
||||||
|
|
||||||
//- setup
|
|
||||||
let o = Object.create({ x: 1, y: 2 });
|
|
||||||
o.z = 3;
|
|
||||||
|
|
||||||
let x, y, z;
|
|
||||||
//- elems
|
|
||||||
{ x, ...{y , z} }
|
|
||||||
//- vals
|
|
||||||
o
|
|
||||||
//- body
|
|
||||||
assert.sameValue(x, 1);
|
|
||||||
assert.sameValue(y, undefined);
|
|
||||||
assert.sameValue(z, 3);
|
|
||||||
|
|
||||||
//- teardown
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,56 +0,0 @@
|
||||||
// This file was procedurally generated from the following sources:
|
|
||||||
// - src/dstr-assignment-for-await/obj-rest-nested-obj-nested-rest.case
|
|
||||||
// - src/dstr-assignment-for-await/default/async-func-decl.template
|
|
||||||
/*---
|
|
||||||
description: When DestructuringAssignmentTarget is an object literal, it should be parsed parsed as a DestructuringAssignmentPattern and evaluated as a destructuring assignment and object rest desconstruction is allowed in that case. (for-await-of statement in an async function declaration)
|
|
||||||
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
|
||||||
features: [object-rest, destructuring-binding, async-iteration]
|
|
||||||
flags: [generated, async]
|
|
||||||
includes: [propertyHelper.js]
|
|
||||||
info: |
|
|
||||||
IterationStatement :
|
|
||||||
for await ( LeftHandSideExpression of AssignmentExpression ) Statement
|
|
||||||
|
|
||||||
1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« »,
|
|
||||||
AssignmentExpression, iterate).
|
|
||||||
2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement,
|
|
||||||
keyResult, assignment, labelSet).
|
|
||||||
|
|
||||||
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
|
||||||
|
|
||||||
[...]
|
|
||||||
5. If destructuring is true and if lhsKind is assignment, then
|
|
||||||
a. Assert: lhs is a LeftHandSideExpression.
|
|
||||||
b. Let assignmentPattern be the parse of the source text corresponding to
|
|
||||||
lhs using AssignmentPattern as the goal symbol.
|
|
||||||
[...]
|
|
||||||
---*/
|
|
||||||
let a, b, c, rest;
|
|
||||||
|
|
||||||
let iterCount = 0;
|
|
||||||
async function fn() {
|
|
||||||
for await ({a, b, ...{c, ...rest}} of [{a: 1, b: 2, c: 3, d: 4, e: 5}]) {
|
|
||||||
assert.sameValue(a, 1);
|
|
||||||
assert.sameValue(b, 2);
|
|
||||||
assert.sameValue(c, 3);
|
|
||||||
|
|
||||||
assert.sameValue(rest.d, 4);
|
|
||||||
assert.sameValue(rest.e, 5);
|
|
||||||
|
|
||||||
verifyEnumerable(rest, "d");
|
|
||||||
verifyWritable(rest, "d");
|
|
||||||
verifyConfigurable(rest, "d");
|
|
||||||
|
|
||||||
verifyEnumerable(rest, "e");
|
|
||||||
verifyWritable(rest, "e");
|
|
||||||
verifyConfigurable(rest, "e");
|
|
||||||
|
|
||||||
iterCount += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let promise = fn();
|
|
||||||
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,46 +0,0 @@
|
||||||
// This file was procedurally generated from the following sources:
|
|
||||||
// - src/dstr-assignment-for-await/obj-rest-nested-obj.case
|
|
||||||
// - src/dstr-assignment-for-await/default/async-func-decl.template
|
|
||||||
/*---
|
|
||||||
description: When DestructuringAssignmentTarget is an object literal, it should be parsed parsed as a DestructuringAssignmentPattern and evaluated as a destructuring assignment. (for-await-of statement in an async function declaration)
|
|
||||||
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
|
||||||
features: [object-rest, destructuring-binding, async-iteration]
|
|
||||||
flags: [generated, async]
|
|
||||||
info: |
|
|
||||||
IterationStatement :
|
|
||||||
for await ( LeftHandSideExpression of AssignmentExpression ) Statement
|
|
||||||
|
|
||||||
1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« »,
|
|
||||||
AssignmentExpression, iterate).
|
|
||||||
2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement,
|
|
||||||
keyResult, assignment, labelSet).
|
|
||||||
|
|
||||||
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
|
||||||
|
|
||||||
[...]
|
|
||||||
5. If destructuring is true and if lhsKind is assignment, then
|
|
||||||
a. Assert: lhs is a LeftHandSideExpression.
|
|
||||||
b. Let assignmentPattern be the parse of the source text corresponding to
|
|
||||||
lhs using AssignmentPattern as the goal symbol.
|
|
||||||
[...]
|
|
||||||
---*/
|
|
||||||
let a, b, c, d, e;
|
|
||||||
|
|
||||||
let iterCount = 0;
|
|
||||||
async function fn() {
|
|
||||||
for await ({a, b, ...{c, e}} of [{a: 1, b: 2, c: 3, d: 4, e: 5}]) {
|
|
||||||
assert.sameValue(a, 1);
|
|
||||||
assert.sameValue(b, 2);
|
|
||||||
assert.sameValue(c, 3);
|
|
||||||
assert.sameValue(e, 5);
|
|
||||||
assert.sameValue(d, undefined);
|
|
||||||
|
|
||||||
iterCount += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let promise = fn();
|
|
||||||
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,47 +0,0 @@
|
||||||
// This file was procedurally generated from the following sources:
|
|
||||||
// - src/dstr-assignment-for-await/obj-rest-obj-own-property.case
|
|
||||||
// - src/dstr-assignment-for-await/default/async-func-decl.template
|
|
||||||
/*---
|
|
||||||
description: Rest object contains just source object's own properties (for-await-of statement in an async function declaration)
|
|
||||||
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
|
||||||
features: [object-rest, destructuring-binding, async-iteration]
|
|
||||||
flags: [generated, async]
|
|
||||||
info: |
|
|
||||||
IterationStatement :
|
|
||||||
for await ( LeftHandSideExpression of AssignmentExpression ) Statement
|
|
||||||
|
|
||||||
1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« »,
|
|
||||||
AssignmentExpression, iterate).
|
|
||||||
2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement,
|
|
||||||
keyResult, assignment, labelSet).
|
|
||||||
|
|
||||||
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
|
||||||
|
|
||||||
[...]
|
|
||||||
5. If destructuring is true and if lhsKind is assignment, then
|
|
||||||
a. Assert: lhs is a LeftHandSideExpression.
|
|
||||||
b. Let assignmentPattern be the parse of the source text corresponding to
|
|
||||||
lhs using AssignmentPattern as the goal symbol.
|
|
||||||
[...]
|
|
||||||
---*/
|
|
||||||
let o = Object.create({ x: 1, y: 2 });
|
|
||||||
o.z = 3;
|
|
||||||
|
|
||||||
let x, y, z;
|
|
||||||
|
|
||||||
let iterCount = 0;
|
|
||||||
async function fn() {
|
|
||||||
for await ({ x, ...{y , z} } of [o]) {
|
|
||||||
assert.sameValue(x, 1);
|
|
||||||
assert.sameValue(y, undefined);
|
|
||||||
assert.sameValue(z, 3);
|
|
||||||
|
|
||||||
iterCount += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let promise = fn();
|
|
||||||
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,56 +0,0 @@
|
||||||
// This file was procedurally generated from the following sources:
|
|
||||||
// - src/dstr-assignment-for-await/obj-rest-nested-obj-nested-rest.case
|
|
||||||
// - src/dstr-assignment-for-await/default/async-gen-decl.template
|
|
||||||
/*---
|
|
||||||
description: When DestructuringAssignmentTarget is an object literal, it should be parsed parsed as a DestructuringAssignmentPattern and evaluated as a destructuring assignment and object rest desconstruction is allowed in that case. (for-await-of statement in an async generator declaration)
|
|
||||||
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
|
||||||
features: [object-rest, destructuring-binding, async-iteration]
|
|
||||||
flags: [generated, async]
|
|
||||||
includes: [propertyHelper.js]
|
|
||||||
info: |
|
|
||||||
IterationStatement :
|
|
||||||
for await ( LeftHandSideExpression of AssignmentExpression ) Statement
|
|
||||||
|
|
||||||
1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« »,
|
|
||||||
AssignmentExpression, iterate).
|
|
||||||
2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement,
|
|
||||||
keyResult, assignment, labelSet).
|
|
||||||
|
|
||||||
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
|
||||||
|
|
||||||
[...]
|
|
||||||
5. If destructuring is true and if lhsKind is assignment, then
|
|
||||||
a. Assert: lhs is a LeftHandSideExpression.
|
|
||||||
b. Let assignmentPattern be the parse of the source text corresponding to
|
|
||||||
lhs using AssignmentPattern as the goal symbol.
|
|
||||||
[...]
|
|
||||||
---*/
|
|
||||||
let a, b, c, rest;
|
|
||||||
|
|
||||||
let iterCount = 0;
|
|
||||||
async function * fn() {
|
|
||||||
for await ({a, b, ...{c, ...rest}} of [{a: 1, b: 2, c: 3, d: 4, e: 5}]) {
|
|
||||||
assert.sameValue(a, 1);
|
|
||||||
assert.sameValue(b, 2);
|
|
||||||
assert.sameValue(c, 3);
|
|
||||||
|
|
||||||
assert.sameValue(rest.d, 4);
|
|
||||||
assert.sameValue(rest.e, 5);
|
|
||||||
|
|
||||||
verifyEnumerable(rest, "d");
|
|
||||||
verifyWritable(rest, "d");
|
|
||||||
verifyConfigurable(rest, "d");
|
|
||||||
|
|
||||||
verifyEnumerable(rest, "e");
|
|
||||||
verifyWritable(rest, "e");
|
|
||||||
verifyConfigurable(rest, "e");
|
|
||||||
|
|
||||||
iterCount += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let promise = fn().next();
|
|
||||||
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,46 +0,0 @@
|
||||||
// This file was procedurally generated from the following sources:
|
|
||||||
// - src/dstr-assignment-for-await/obj-rest-nested-obj.case
|
|
||||||
// - src/dstr-assignment-for-await/default/async-gen-decl.template
|
|
||||||
/*---
|
|
||||||
description: When DestructuringAssignmentTarget is an object literal, it should be parsed parsed as a DestructuringAssignmentPattern and evaluated as a destructuring assignment. (for-await-of statement in an async generator declaration)
|
|
||||||
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
|
||||||
features: [object-rest, destructuring-binding, async-iteration]
|
|
||||||
flags: [generated, async]
|
|
||||||
info: |
|
|
||||||
IterationStatement :
|
|
||||||
for await ( LeftHandSideExpression of AssignmentExpression ) Statement
|
|
||||||
|
|
||||||
1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« »,
|
|
||||||
AssignmentExpression, iterate).
|
|
||||||
2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement,
|
|
||||||
keyResult, assignment, labelSet).
|
|
||||||
|
|
||||||
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
|
||||||
|
|
||||||
[...]
|
|
||||||
5. If destructuring is true and if lhsKind is assignment, then
|
|
||||||
a. Assert: lhs is a LeftHandSideExpression.
|
|
||||||
b. Let assignmentPattern be the parse of the source text corresponding to
|
|
||||||
lhs using AssignmentPattern as the goal symbol.
|
|
||||||
[...]
|
|
||||||
---*/
|
|
||||||
let a, b, c, d, e;
|
|
||||||
|
|
||||||
let iterCount = 0;
|
|
||||||
async function * fn() {
|
|
||||||
for await ({a, b, ...{c, e}} of [{a: 1, b: 2, c: 3, d: 4, e: 5}]) {
|
|
||||||
assert.sameValue(a, 1);
|
|
||||||
assert.sameValue(b, 2);
|
|
||||||
assert.sameValue(c, 3);
|
|
||||||
assert.sameValue(e, 5);
|
|
||||||
assert.sameValue(d, undefined);
|
|
||||||
|
|
||||||
iterCount += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let promise = fn().next();
|
|
||||||
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
|
@ -1,47 +0,0 @@
|
||||||
// This file was procedurally generated from the following sources:
|
|
||||||
// - src/dstr-assignment-for-await/obj-rest-obj-own-property.case
|
|
||||||
// - src/dstr-assignment-for-await/default/async-gen-decl.template
|
|
||||||
/*---
|
|
||||||
description: Rest object contains just source object's own properties (for-await-of statement in an async generator declaration)
|
|
||||||
esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation
|
|
||||||
features: [object-rest, destructuring-binding, async-iteration]
|
|
||||||
flags: [generated, async]
|
|
||||||
info: |
|
|
||||||
IterationStatement :
|
|
||||||
for await ( LeftHandSideExpression of AssignmentExpression ) Statement
|
|
||||||
|
|
||||||
1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« »,
|
|
||||||
AssignmentExpression, iterate).
|
|
||||||
2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement,
|
|
||||||
keyResult, assignment, labelSet).
|
|
||||||
|
|
||||||
13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation
|
|
||||||
|
|
||||||
[...]
|
|
||||||
5. If destructuring is true and if lhsKind is assignment, then
|
|
||||||
a. Assert: lhs is a LeftHandSideExpression.
|
|
||||||
b. Let assignmentPattern be the parse of the source text corresponding to
|
|
||||||
lhs using AssignmentPattern as the goal symbol.
|
|
||||||
[...]
|
|
||||||
---*/
|
|
||||||
let o = Object.create({ x: 1, y: 2 });
|
|
||||||
o.z = 3;
|
|
||||||
|
|
||||||
let x, y, z;
|
|
||||||
|
|
||||||
let iterCount = 0;
|
|
||||||
async function * fn() {
|
|
||||||
for await ({ x, ...{y , z} } of [o]) {
|
|
||||||
assert.sameValue(x, 1);
|
|
||||||
assert.sameValue(y, undefined);
|
|
||||||
assert.sameValue(z, 3);
|
|
||||||
|
|
||||||
iterCount += 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
let promise = fn().next();
|
|
||||||
|
|
||||||
promise
|
|
||||||
.then(() => assert.sameValue(iterCount, 1, 'iteration occurred as expected'), $DONE)
|
|
||||||
.then($DONE, $DONE);
|
|
Loading…
Reference in New Issue