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)); | 
| }()); |