v8/test/mjsunit/regress/regress-4525.js
mstarzinger 26f90c95cc [turbofan] Fix super property calls to act as method calls.
This fixes [NAMED|KEYED]_SUPER_PROPERTY_CALL to perform a method call
instead of a function call. The difference is visible for sloppy mode
targets that convert primitive receivers.

R=rossberg@chromium.org
TEST=mjsunit/regress/regress-4525
BUG=v8:4525
LOG=n

Review URL: https://codereview.chromium.org/1419173004

Cr-Commit-Position: refs/heads/master@{#31664}
2015-10-29 17:19:39 +00:00

40 lines
1.1 KiB
JavaScript

// Copyright 2015 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
function receiver() {
return this;
}
function construct(f) {
"use strict";
class B {}
class C extends B {
bar() { return super.foo() }
}
B.prototype.foo = f;
return new C();
}
function check(x, value, type) {
assertEquals("object", typeof x);
assertInstanceof(x, type);
assertEquals(value, x);
}
var o = construct(receiver);
check(o.bar.call(123), Object(123), Number);
check(o.bar.call("a"), Object("a"), String);
// TODO(4526): Should convert to global receiver instead of throwing TypeError.
// check(o.bar.call(undefined), this, Object);
// check(o.bar.call(null), this, Object);
%OptimizeFunctionOnNextCall(o.bar);
check(o.bar.call(456), Object(456), Number);
check(o.bar.call("b"), Object("b"), String);
// TODO(4526): Should convert to global receiver instead of throwing TypeError.
// check(o.bar.call(undefined), this, Object);
// check(o.bar.call(null), this, Object);