v8/test/mjsunit/regress/regress-crbug-662907.js
ishell 39e6f2ca4a [ic] Use validity cells to protect keyed element stores against object's prototype chain modifications.
... instead of clearing of all the KeyedStoreICs which didn't always work.

BUG=chromium:662907, chromium:669411, v8:5561
TBR=verwaest@chromium.org, bmeurer@chromium.org

Committed: https://crrev.com/a39522f44f7e0be4686831688917e9675255dcaf
Review-Url: https://codereview.chromium.org/2534613002
Cr-Original-Commit-Position: refs/heads/master@{#41332}
Cr-Commit-Position: refs/heads/master@{#41449}
2016-12-02 10:03:33 +00:00

54 lines
1.1 KiB
JavaScript

// Copyright 2016 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.
// Flags: --allow-natives-syntax --expose-gc
(function() {
function foo() {
var a = new Array();
a[0] = 10;
return a;
}
assertEquals(1, foo().length);
gc();
gc();
gc();
gc();
// Change prototype elements from fast smi to slow elements dictionary.
// The validity cell is invalidated by the change of Array.prototype's
// map.
Array.prototype.__defineSetter__("0", function() {});
assertEquals(0, foo().length);
})();
(function() {
function foo() {
var a = new Array();
a[0] = 10;
return a;
}
// Change prototype elements from fast smi to dictionary.
Array.prototype[123456789] = 42;
Array.prototype.length = 0;
assertEquals(1, foo().length);
gc();
gc();
gc();
gc();
// Change prototype elements from dictionary to slow elements dictionary.
// The validity cell is invalidated by making the elements dictionary slow.
Array.prototype.__defineSetter__("0", function() {});
assertEquals(0, foo().length);
})();