89 lines
2.8 KiB
JavaScript
89 lines
2.8 KiB
JavaScript
|
// 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.
|
||
|
|
||
|
// The bug was that destructuring assignments which occur inside a lazy arrow
|
||
|
// function parameter list were not rewritten.
|
||
|
|
||
|
// Repro from the bug (slightly modified so that it doesn't produce a run-time
|
||
|
// exception).
|
||
|
(({x = {} = {}}) => {})({});
|
||
|
|
||
|
// ... and without the parens.
|
||
|
let a0 = ({x = {} = {}}) => {};
|
||
|
a0({});
|
||
|
|
||
|
// Testing that the destructuring assignments also work properly. The semantics
|
||
|
// are: The value of the destructuring assignment is an object {myprop: 2115}
|
||
|
// and 2115 also gets assigned to global_side_assignment. So the default value
|
||
|
// for x is {myprop: 2115}. This is the value which x will have if the function
|
||
|
// is called with an object which doesn't have property x.
|
||
|
let called = false;
|
||
|
let global_side_assignment = undefined;
|
||
|
(({x = {myprop: global_side_assignment} = {myprop: 2115}}) => {
|
||
|
assertTrue('myprop' in x);
|
||
|
assertEquals(2115, x.myprop);
|
||
|
called = true;
|
||
|
})({});
|
||
|
assertTrue(called);
|
||
|
assertEquals(2115, global_side_assignment);
|
||
|
|
||
|
// If the parameter is an object which has property x, the default value is not
|
||
|
// used.
|
||
|
called = false;
|
||
|
global_side_assignment = undefined;
|
||
|
(({x = {myprop: global_side_assignment} = {myprop: 2115}}) => {
|
||
|
assertEquals(3000, x);
|
||
|
called = true;
|
||
|
})({x: 3000});
|
||
|
assertTrue(called);
|
||
|
// Global side assignment doesn't happen, since the default value was not used.
|
||
|
assertEquals(undefined, global_side_assignment);
|
||
|
|
||
|
// Different kinds of lazy arrow functions (it's actually a bit weird that the
|
||
|
// above functions are lazy, since they are parenthesized).
|
||
|
called = false;
|
||
|
global_side_assignment = undefined;
|
||
|
let a1 = ({x = {myprop: global_side_assignment} = {myprop: 2115}}) => {
|
||
|
assertTrue('myprop' in x);
|
||
|
assertEquals(2115, x.myprop);
|
||
|
called = true;
|
||
|
}
|
||
|
a1({});
|
||
|
assertTrue(called);
|
||
|
assertEquals(2115, global_side_assignment);
|
||
|
|
||
|
called = false;
|
||
|
global_side_assignment = undefined;
|
||
|
let a2 = ({x = {myprop: global_side_assignment} = {myprop: 2115}}) => {
|
||
|
assertEquals(3000, x);
|
||
|
called = true;
|
||
|
}
|
||
|
a2({x: 3000});
|
||
|
assertTrue(called);
|
||
|
assertEquals(undefined, global_side_assignment);
|
||
|
|
||
|
// We never had a problem with non-arrow functions, but testing them too for
|
||
|
// completeness.
|
||
|
called = false;
|
||
|
global_side_assignment = undefined;
|
||
|
function f1({x = {myprop: global_side_assignment} = {myprop: 2115}}) {
|
||
|
assertTrue('myprop' in x);
|
||
|
assertEquals(2115, x.myprop);
|
||
|
assertEquals(2115, global_side_assignment);
|
||
|
called = true;
|
||
|
}
|
||
|
f1({});
|
||
|
assertTrue(called);
|
||
|
assertEquals(2115, global_side_assignment);
|
||
|
|
||
|
called = false;
|
||
|
global_side_assignment = undefined;
|
||
|
function f2({x = {myprop: global_side_assignment} = {myprop: 2115}}) {
|
||
|
assertEquals(3000, x);
|
||
|
called = true;
|
||
|
}
|
||
|
f2({x: 3000});
|
||
|
assertTrue(called);
|
||
|
assertEquals(undefined, global_side_assignment);
|