| Index: test/mjsunit/harmony/toMethod.js
|
| diff --git a/test/mjsunit/harmony/toMethod.js b/test/mjsunit/harmony/toMethod.js
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ad51b2ff3809001d159443c731408c86f3f36902
|
| --- /dev/null
|
| +++ b/test/mjsunit/harmony/toMethod.js
|
| @@ -0,0 +1,115 @@
|
| +// Copyright 2014 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: --harmony-classes --allow-natives-syntax
|
| +
|
| +
|
| +(function TestSingleClass() {
|
| + function f(x) {
|
| + var a = [0, 1, 2]
|
| + return a[x];
|
| + }
|
| +
|
| + function ClassD() { }
|
| +
|
| + assertEquals(1, f(1));
|
| + var g = f.toMethod(ClassD.prototype);
|
| + assertEquals(1, g(1));
|
| + assertEquals(undefined, f[%HomeObjectSymbol()]);
|
| + assertEquals(ClassD.prototype, g[%HomeObjectSymbol()]);
|
| +}());
|
| +
|
| +
|
| +(function TestClassHierarchy() {
|
| + function f(x) {
|
| + return function g(y) { x++; return x + y; };
|
| + }
|
| +
|
| + function Base() {}
|
| + function Derived() { }
|
| + Derived.prototype = Object.create(Base.prototype);
|
| +
|
| + var q = f(0);
|
| + assertEquals(2, q(1));
|
| + assertEquals(3, q(1));
|
| + var g = q.toMethod(Derived.prototype);
|
| + assertFalse(g === q);
|
| + assertEquals(4, g(1));
|
| + assertEquals(5, q(1));
|
| +}());
|
| +
|
| +
|
| +(function TestErrorCases() {
|
| + var sFun = Function.prototype.toMethod;
|
| + assertThrows(function() { sFun.call({}); }, TypeError);
|
| + assertThrows(function() { sFun.call({}, {}); }, TypeError);
|
| + function f(){};
|
| + assertThrows(function() { f.toMethod(1); }, TypeError);
|
| +}());
|
| +
|
| +
|
| +(function TestPrototypeChain() {
|
| + var o = {};
|
| + var o1 = {};
|
| + function f() { }
|
| +
|
| + function g() { }
|
| +
|
| + var fMeth = f.toMethod(o);
|
| + assertEquals(o, fMeth[%HomeObjectSymbol()]);
|
| + g.__proto__ = fMeth;
|
| + assertEquals(undefined, g[%HomeObjectSymbol()]);
|
| + var gMeth = g.toMethod(o1);
|
| + assertEquals(fMeth, gMeth.__proto__);
|
| + assertEquals(o, fMeth[%HomeObjectSymbol()]);
|
| + assertEquals(o1, gMeth[%HomeObjectSymbol()]);
|
| +}());
|
| +
|
| +
|
| +(function TestBoundFunction() {
|
| + var o = {};
|
| + var p = {};
|
| +
|
| +
|
| + function f(x, y, z, w) {
|
| + assertEquals(o, this);
|
| + assertEquals(1, x);
|
| + assertEquals(2, y);
|
| + assertEquals(3, z);
|
| + assertEquals(4, w);
|
| + return x+y+z+w;
|
| + }
|
| +
|
| + var fBound = f.bind(o, 1, 2, 3);
|
| + var fMeth = fBound.toMethod(p);
|
| + assertEquals(10, fMeth(4));
|
| + assertEquals(10, fMeth.call(p, 4));
|
| + var fBound1 = fBound.bind(o, 4);
|
| + assertEquals(10, fBound1());
|
| + var fMethBound = fMeth.bind(o, 4);
|
| + assertEquals(10, fMethBound());
|
| +}());
|
| +
|
| +(function TestOptimized() {
|
| + function f(o) {
|
| + return o.x;
|
| + }
|
| + var o = {x : 15};
|
| + assertEquals(15, f(o));
|
| + assertEquals(15, f(o));
|
| + %OptimizeFunctionOnNextCall(f);
|
| + assertEquals(15, f(o));
|
| + var g = f.toMethod({});
|
| + var o1 = {y : 1024, x : "abc"};
|
| + assertEquals("abc", f(o1));
|
| + assertEquals("abc", g(o1));
|
| +} ());
|
| +
|
| +(function TestExtensibility() {
|
| + function f() {}
|
| + Object.preventExtensions(f);
|
| + assertFalse(Object.isExtensible(f));
|
| + var m = f.toMethod({});
|
| + assertTrue(Object.isExtensible(m));
|
| +}());
|
|
|