Chromium Code Reviews| Index: test/mjsunit/harmony/toMethod.js |
| diff --git a/test/mjsunit/harmony/toMethod.js b/test/mjsunit/harmony/toMethod.js |
| index ad51b2ff3809001d159443c731408c86f3f36902..0466aa100c0aa48adaf971f45a74d257c3a984a7 100644 |
| --- a/test/mjsunit/harmony/toMethod.js |
| +++ b/test/mjsunit/harmony/toMethod.js |
| @@ -5,6 +5,10 @@ |
| // Flags: --harmony-classes --allow-natives-syntax |
| +// Function.prototype.toMethod was removed from the spec so this test |
|
adamk
2015/02/10 21:27:29
I don't think this comment is helpful. git blame w
|
| +// was modified to call the runtime function directly. |
| + |
| + |
| (function TestSingleClass() { |
| function f(x) { |
| var a = [0, 1, 2] |
| @@ -14,7 +18,7 @@ |
| function ClassD() { } |
| assertEquals(1, f(1)); |
| - var g = f.toMethod(ClassD.prototype); |
| + var g = %ToMethod(f, ClassD.prototype); |
| assertEquals(1, g(1)); |
| assertEquals(undefined, f[%HomeObjectSymbol()]); |
| assertEquals(ClassD.prototype, g[%HomeObjectSymbol()]); |
| @@ -33,22 +37,13 @@ |
| var q = f(0); |
| assertEquals(2, q(1)); |
| assertEquals(3, q(1)); |
| - var g = q.toMethod(Derived.prototype); |
| + var g = %ToMethod(q, 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 = {}; |
| @@ -56,11 +51,11 @@ |
| function g() { } |
| - var fMeth = f.toMethod(o); |
| + var fMeth = %ToMethod(f, o); |
| assertEquals(o, fMeth[%HomeObjectSymbol()]); |
| g.__proto__ = fMeth; |
| assertEquals(undefined, g[%HomeObjectSymbol()]); |
| - var gMeth = g.toMethod(o1); |
| + var gMeth = %ToMethod(g, o1); |
| assertEquals(fMeth, gMeth.__proto__); |
| assertEquals(o, fMeth[%HomeObjectSymbol()]); |
| assertEquals(o1, gMeth[%HomeObjectSymbol()]); |
| @@ -82,7 +77,7 @@ |
| } |
| var fBound = f.bind(o, 1, 2, 3); |
| - var fMeth = fBound.toMethod(p); |
| + var fMeth = %ToMethod(fBound, p); |
| assertEquals(10, fMeth(4)); |
| assertEquals(10, fMeth.call(p, 4)); |
| var fBound1 = fBound.bind(o, 4); |
| @@ -100,7 +95,7 @@ |
| assertEquals(15, f(o)); |
| %OptimizeFunctionOnNextCall(f); |
| assertEquals(15, f(o)); |
| - var g = f.toMethod({}); |
| + var g = %ToMethod(f, {}); |
| var o1 = {y : 1024, x : "abc"}; |
| assertEquals("abc", f(o1)); |
| assertEquals("abc", g(o1)); |
| @@ -110,6 +105,6 @@ |
| function f() {} |
| Object.preventExtensions(f); |
| assertFalse(Object.isExtensible(f)); |
| - var m = f.toMethod({}); |
| + var m = %ToMethod(f, {}); |
| assertTrue(Object.isExtensible(m)); |
| }()); |