blob: c3f516199baa68e66cb215b1023a38c3df26199a [file] [log] [blame]
// Copyright 2017 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
(function regressionCaseOne() {
var c;
for (let [a, b = c = function() { return a + b }] of [[0]]) {
function f() { return a };
}
c();
})();
(function testForInFunction() {
for (const {length: a, b = function() { return a, b }} in {foo: 42}) {
assertSame(b, (function() { return b() })());
}
})();
(function testForOfFunction() {
for (const [a, b = function() { return a, b }] of [[42]]) {
assertSame(b, (function() { return b() })());
}
})();
(function testForInVariableProxy() {
for (const {length: a, b = a} in {foo: 42}) {
assertEquals(3, a);
assertEquals(a, b);
}
})();
(function testForOfVariableProxy() {
for (const [a, b = a] of [[42]]) {
assertEquals(42, a);
assertEquals(a, b);
}
})();
(function testClassLiteral() {
for (let { a, b = class c { static f() { return a, b } } } of [{}]) {
assertSame(b, (function() { return b.f() })());
}
})();
// Methods in class literals remain inside the
// class scope after scope reparenting.
(function testClassLiteralMethod() {
for (let { a, b = class c { m() { return c } } } of [{}]) {
assertSame(b, (function() { return (new b).m() })());
}
})();
// Function literals in computed class names remain inside the
// class scope after scope reparenting.
(function testClassLiteralComputedName() {
let d;
for (let { a, b = class c { [d = function() { return c }]() { } } } of [{}]) {
assertSame(b, (function() { return b, d() })());
}
})();
// Function literals in class extends expressions names remain inside the
// class scope after scope reparenting.
(function testClassLiteralComputedName() {
let d;
for (let { a, b = class c extends (d = function() { return c }, Object) { } } of [{}]) {
assertSame(b, (function() { return b, d() })());
}
})();