Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 // | 4 // |
| 5 // Flags: --experimental-classes --harmony-classes | 5 // Flags: --experimental-classes --harmony-classes |
| 6 | 6 |
| 7 'use strict'; | 7 'use strict'; |
| 8 | 8 (function TestArgumentsAccess() { |
| 9 class Base { | 9 class Base { |
| 10 constructor(a, b) { | 10 constructor() { |
| 11 let o = new Object(); | 11 assertEquals(2, arguments.length); |
| 12 o.prp = a + b; | 12 assertEquals(1, arguments[0]); |
| 13 return o; | 13 assertEquals(2, arguments[1]); |
| 14 } | 14 } |
| 15 } | 15 } |
| 16 | 16 |
| 17 class Subclass extends Base { | 17 let b = new Base(1,2); |
| 18 constructor(a, b) { | 18 |
| 19 var exn; | 19 class Subclass extends Base { |
| 20 try { | 20 constructor() { |
| 21 this.prp1 = 3; | 21 assertEquals(2, arguments.length); |
| 22 } catch (e) { | 22 assertEquals(3, arguments[0]); |
| 23 exn = e; | 23 assertEquals(4, arguments[1]); |
| 24 } | 24 super(1,2); |
| 25 assertTrue(exn instanceof ReferenceError); | 25 } |
| 26 super(a, b); | 26 } |
| 27 assertSame(a + b, this.prp); | 27 |
| 28 assertSame(undefined, this.prp1); | 28 let s = new Subclass(3,4); |
| 29 assertFalse(this.hasOwnProperty("prp1")); | 29 assertEquals(0, Subclass.length); |
| 30 return this; | 30 |
| 31 } | 31 class Subclass2 extends Base { |
| 32 } | 32 constructor(x,y) { |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
ws after commma
| |
| 33 | 33 assertEquals(2, arguments.length); |
| 34 let b = new Base(1, 2); | 34 assertEquals(3, arguments[0]); |
| 35 assertSame(3, b.prp); | 35 assertEquals(4, arguments[1]); |
| 36 | 36 super(1,2); |
| 37 | 37 } |
| 38 let s = new Subclass(2, -1); | 38 } |
| 39 assertSame(1, s.prp); | 39 |
| 40 assertSame(undefined, s.prp1); | 40 let s2 = new Subclass2(3,4); |
| 41 assertFalse(s.hasOwnProperty("prp1")); | 41 assertEquals(2, Subclass2.length); |
| 42 | 42 }()); |
| 43 class Subclass2 extends Base { | 43 |
| 44 constructor(x) { | 44 (function TestThisAccessRestriction() { |
| 45 super(1,2); | 45 class Base { |
| 46 | 46 constructor(a, b) { |
| 47 if (x < 0) return; | 47 let o = new Object(); |
| 48 | 48 o.prp = a + b; |
| 49 let called = false; | 49 return o; |
| 50 function tmp() { called = true; return 3; } | 50 } |
| 51 var exn = null; | 51 } |
| 52 try { | 52 |
| 53 super(tmp(),4); | 53 class Subclass extends Base { |
| 54 } catch(e) { exn = e; } | 54 constructor(a, b) { |
| 55 assertTrue(exn !== null); | 55 var exn; |
| 56 assertFalse(called); | 56 try { |
| 57 } | 57 this.prp1 = 3; |
| 58 } | 58 } catch (e) { |
| 59 | 59 exn = e; |
| 60 var s2 = new Subclass2(1); | 60 } |
| 61 assertSame(3, s2.prp); | 61 assertTrue(exn instanceof ReferenceError); |
| 62 | 62 super(a, b); |
| 63 var s3 = new Subclass2(-1); | 63 assertSame(a + b, this.prp); |
| 64 assertSame(3, s3.prp); | 64 assertSame(undefined, this.prp1); |
| 65 | 65 assertFalse(this.hasOwnProperty("prp1")); |
| 66 assertThrows(function() { Subclass.call(new Object(), 1, 2); }, TypeError); | 66 return this; |
| 67 assertThrows(function() { Base.call(new Object(), 1, 2); }, TypeError); | 67 } |
| 68 } | |
| 69 | |
| 70 let b = new Base(1, 2); | |
| 71 assertSame(3, b.prp); | |
| 72 | |
| 73 | |
| 74 let s = new Subclass(2, -1); | |
| 75 assertSame(1, s.prp); | |
| 76 assertSame(undefined, s.prp1); | |
| 77 assertFalse(s.hasOwnProperty("prp1")); | |
| 78 | |
| 79 class Subclass2 extends Base { | |
| 80 constructor(x) { | |
| 81 super(1,2); | |
| 82 | |
| 83 if (x < 0) return; | |
| 84 | |
| 85 let called = false; | |
| 86 function tmp() { called = true; return 3; } | |
| 87 var exn = null; | |
| 88 try { | |
| 89 super(tmp(),4); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
Because left to right execution?
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
I realized this is not correct under the new spec.
| |
| 90 } catch(e) { exn = e; } | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
ws after catch
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 91 assertTrue(exn !== null); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
instanceof test would be better
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 92 assertFalse(called); | |
| 93 } | |
| 94 } | |
| 95 | |
| 96 var s2 = new Subclass2(1); | |
| 97 assertSame(3, s2.prp); | |
| 98 | |
| 99 var s3 = new Subclass2(-1); | |
| 100 assertSame(3, s3.prp); | |
| 101 | |
| 102 assertThrows(function() { Subclass.call(new Object(), 1, 2); }, TypeError); | |
| 103 assertThrows(function() { Base.call(new Object(), 1, 2); }, TypeError); | |
| 104 | |
| 105 class BadSubclass extends Base { | |
| 106 constructor() {} | |
| 107 } | |
| 108 | |
| 109 assertThrows(function() { new BadSubclass(); }, ReferenceError); | |
| 110 }()); | |
| 111 | |
| 112 (function TestPrototypeWiring() { | |
| 113 class Base { | |
| 114 constructor(x) { | |
| 115 this.foobar = x; | |
| 116 } | |
| 117 } | |
| 118 | |
| 119 class Subclass extends Base { | |
| 120 constructor(x) { | |
| 121 super(x); | |
| 122 } | |
| 123 } | |
| 124 | |
| 125 let s = new Subclass(1); | |
| 126 assertSame(1, s.foobar); | |
| 127 assertTrue(s.__proto__ === Subclass.prototype); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
assertSame here too
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 128 | |
| 129 let s1 = new Subclass(1,2); | |
| 130 assertSame(1, s1.foobar); | |
| 131 assertTrue(s1.__proto__ === Subclass.prototype); | |
| 132 | |
| 133 let s2 = new Subclass(); | |
| 134 assertSame(undefined, s2.foobar); | |
| 135 assertTrue(s2.__proto__ === Subclass.prototype); | |
| 136 assertThrows(function() { Subclass(1); }, TypeError); | |
| 137 assertThrows(function() { Subclass(1,2,3,4); }, TypeError); | |
| 138 | |
| 139 class Subclass2 extends Subclass { | |
| 140 constructor() { | |
| 141 super(5,6,7); | |
| 142 } | |
| 143 } | |
| 144 | |
| 145 let s_2 = new Subclass2(); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
no underscores in js
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 146 assertSame(5, s_2.foobar); | |
| 147 assertTrue(s_2.__proto__ === Subclass2.prototype); | |
| 148 | |
| 149 class Subclass3 extends Base { | |
| 150 constructor(x,y) { | |
| 151 super(x+y); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
ws around binops
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 152 } | |
| 153 } | |
| 154 | |
| 155 let s_3 = new Subclass3(27,42-27); | |
| 156 assertSame(42, s_3.foobar); | |
| 157 assertTrue(s_3.__proto__ === Subclass3.prototype); | |
| 158 }()); | |
| 159 | |
| 160 (function TestSublclassingBuiltins() { | |
| 161 class ExtendedUint8Array extends Uint8Array { | |
| 162 constructor() { | |
| 163 super(10); | |
| 164 this[0] = 255; | |
| 165 this[1] = 0xFFA; | |
| 166 } | |
| 167 } | |
| 168 | |
| 169 var eua = new ExtendedUint8Array(); | |
| 170 assertEquals(10, eua.length); | |
| 171 assertEquals(10, eua.byteLength); | |
| 172 assertEquals(0xFF, eua[0]); | |
| 173 assertEquals(0xFA, eua[1]); | |
| 174 assertTrue(eua.__proto__ === ExtendedUint8Array.prototype); | |
| 175 assertEquals("[object Uint8Array]", Object.prototype.toString.call(eua)); | |
| 176 }()); | |
| 177 | |
| 178 (function TestSubclassingNull() { | |
| 179 let N = null; | |
| 180 | |
| 181 class Foo extends N { | |
| 182 constructor(x,y) { | |
| 183 assertSame(1, x); | |
| 184 assertSame(2, y); | |
| 185 return new Object(); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
in general, prefer {} over new Object()
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 186 } | |
| 187 } | |
| 188 | |
| 189 new Foo(1,2); | |
| 190 }()); | |
| 191 | |
| 192 (function TestSubclassBinding() { | |
| 193 class Base { | |
| 194 constructor(x, y) { | |
| 195 this.x = x; | |
| 196 this.y = y; | |
| 197 } | |
| 198 } | |
| 199 class Subclass extends Base { | |
| 200 constructor(x,y) { | |
| 201 super(x,y); | |
| 202 } | |
| 203 } | |
| 204 | |
| 205 let f = Subclass.bind(new Object()); | |
|
arv (Not doing code reviews)
2015/02/10 20:15:18
Bind a parameter too.
let f = Subclass.bind({}, 1
arv (Not doing code reviews)
2015/02/10 20:15:18
maybe
let obj = {};
let f = Subclass.bind(obj);
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
Dmitry Lomov (no reviews)
2015/02/11 00:58:29
Done.
| |
| 206 assertThrows(function () { f(1,2); }, TypeError); | |
| 207 let s = new f(1,2); | |
| 208 assertSame(1, s.x); | |
| 209 assertSame(2, s.y); | |
| 210 assertTrue(s.__proto__ === Subclass.prototype); | |
| 211 | |
| 212 let s1 = new f(1); | |
| 213 assertSame(1, s1.x); | |
| 214 assertSame(undefined, s1.y); | |
| 215 assertTrue(s1.__proto__ === Subclass.prototype); | |
| 216 }()); | |
| OLD | NEW |