diff options
author | Ali Ijaz Sheikh <ofrobots@google.com> | 2016-01-20 09:45:45 -0800 |
---|---|---|
committer | Ali Ijaz Sheikh <ofrobots@google.com> | 2016-01-21 16:53:58 -0800 |
commit | ef4170ea03a80b21b2d8a65ce432efaa370fe2fa (patch) | |
tree | e382b1b38b729cd8155b56b441c3a563914854a3 /deps/v8/test/mjsunit/regress/regress-4525.js | |
parent | 5f6dfab832979999d2f806fc1a2f1c11a25b0f35 (diff) | |
download | node-new-ef4170ea03a80b21b2d8a65ce432efaa370fe2fa.tar.gz |
deps: upgrade to V8 4.8.271.17
Pick up V8 4.8 branch-head. This branch brings in @@isConcatSpreadable,
@@toPrimitive and ToLength ES6 changes. For full details see:
http://v8project.blogspot.de/2015/11/v8-release-48.html
https://github.com/v8/v8/commit/fa163e2
Ref: https://github.com/nodejs/node/pull/4399
PR-URL: https://github.com/nodejs/node/pull/4785
Reviewed-By: bnoordhuis - Ben Noordhuis <info@bnoordhuis.nl>
Diffstat (limited to 'deps/v8/test/mjsunit/regress/regress-4525.js')
-rw-r--r-- | deps/v8/test/mjsunit/regress/regress-4525.js | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/deps/v8/test/mjsunit/regress/regress-4525.js b/deps/v8/test/mjsunit/regress/regress-4525.js new file mode 100644 index 0000000000..b962dc07ca --- /dev/null +++ b/deps/v8/test/mjsunit/regress/regress-4525.js @@ -0,0 +1,37 @@ +// 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); +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); +check(o.bar.call(undefined), this, Object); +check(o.bar.call(null), this, Object); |