v8/test/mjsunit/regress/regress-crbug-706642.js
bmeurer c019e53cbb [turbofan] Disable inlining of derived class constructors.
The inlining logic doesn't account for the fact that the derived
constructor could return a primitive, thus leaking the implicit
receiver (which is the hole).

R=jarin@chromium.org
BUG=chromium:706642

Review-Url: https://codereview.chromium.org/2788603002
Cr-Commit-Position: refs/heads/master@{#44264}
2017-03-30 10:17:10 +00:00

38 lines
835 B
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.
// Flags: --allow-natives-syntax
class A extends Object {
constructor(arg) {
super();
superclass_counter++;
if (superclass_counter === 3) {
return 1;
}
}
}
class B extends A {
constructor() {
let x = super(123);
return x.a;
}
}
var superclass_counter = 0;
var observer = new Proxy(A, {
get(target, property, receiver) {
if (property === 'prototype') {
%DeoptimizeFunction(B);
}
return Reflect.get(target, property, receiver);
}
});
Reflect.construct(B, [], observer);
Reflect.construct(B, [], observer);
%OptimizeFunctionOnNextCall(B);
assertThrows(() => Reflect.construct(B, [], observer), TypeError);