Index: test/mjsunit/harmony/class-fields-scoping.js |
diff --git a/test/mjsunit/harmony/class-fields-scoping.js b/test/mjsunit/harmony/class-fields-scoping.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0eb953f77bafbd4fd060feee90875b8b0eff56eb |
--- /dev/null |
+++ b/test/mjsunit/harmony/class-fields-scoping.js |
@@ -0,0 +1,314 @@ |
+// Copyright 2016 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-class-fields |
+ |
+// this |
+{ |
+ class C { |
+ a = this; |
+ } |
+ |
+ let c = new C; |
+ assertEquals(c, c.a); |
+} |
+ |
+{ |
+ class C { |
+ static a = this; |
+ } |
+ assertEquals(C, C.a); |
+} |
+ |
+{ |
+ let sigil = {}; |
+ |
+ function outer() { |
+ let stored = null; |
+ class C { |
+ [stored = this] = 0; |
+ } |
+ |
+ assertEquals(sigil, stored); |
+ } |
+ |
+ outer.call(sigil); |
+} |
+ |
+// super |
+{ |
+ class Base { |
+ m() { |
+ return 0; |
+ } |
+ } |
+ |
+ class Derived extends Base { |
+ m() { |
+ return 1; |
+ } |
+ a = super.m(); |
+ } |
+ |
+ let c = new Derived; |
+ assertEquals(0, c.a); |
+} |
+ |
+{ |
+ class Base { |
+ static m() { |
+ return 0; |
+ } |
+ } |
+ |
+ class Derived extends Base { |
+ static m() { |
+ return 1; |
+ } |
+ static a = super.m(); |
+ } |
+ |
+ assertEquals(0, Derived.a); |
+} |
+ |
+{ |
+ let stored = null; |
+ |
+ class OuterBase { |
+ m() { |
+ return 0; |
+ } |
+ } |
+ |
+ class OuterDerived extends OuterBase { |
+ m() { |
+ return 1; |
+ } |
+ |
+ constructor() { |
+ super(); |
+ |
+ class InnerBase { |
+ m() { |
+ return 2; |
+ } |
+ } |
+ |
+ class InnerDerived extends InnerBase { |
+ m() { |
+ return 3; |
+ } |
+ [stored = super.m()] = 0; |
+ } |
+ } |
+ } |
+ |
+ new OuterDerived; |
+ |
+ assertEquals(0, stored); |
+} |
+ |
+// new.target |
+{ |
+ function outer() { |
+ class C { |
+ a = new.target; |
+ } |
+ |
+ let c = new C; |
+ assertTrue(c.hasOwnProperty('a')); |
+ assertEquals(undefined, c.a); |
+ } |
+ |
+ new outer; |
+} |
+ |
+{ |
+ function outer() { |
+ class C { |
+ static a = new.target; |
+ } |
+ |
+ assertTrue(C.hasOwnProperty('a')); |
+ assertEquals(undefined, C.a); |
+ } |
+ |
+ new outer; |
+} |
+ |
+{ |
+ function outer() { |
+ let stored = null; |
+ |
+ class C { |
+ [stored = new.target] = 0; |
+ } |
+ assertEquals(outer, stored); |
+ } |
+ |
+ new outer; |
+} |
+ |
+// arguments |
+{ |
+ function outer() { |
+ let stored_outer = arguments; |
+ let stored_ctor; |
+ |
+ class C { |
+ a = arguments; |
+ |
+ constructor() { |
+ stored_ctor = arguments; |
+ } |
+ } |
+ |
+ let c = new C; |
+ assertEquals('[object Arguments]', Object.prototype.toString.call(c.a)); |
+ assertFalse(stored_outer === c.a); |
+ assertFalse(stored_ctor === c.a); |
+ } |
+ |
+ outer(); |
+} |
+ |
+{ |
+ function outer() { |
+ let stored_outer = arguments; |
+ |
+ class C { |
+ static a = arguments; |
+ } |
+ |
+ assertEquals('[object Arguments]', Object.prototype.toString.call(C.a)); |
+ assertFalse(stored_outer === C.a); |
+ } |
+ |
+ outer(); |
+} |
+ |
+{ |
+ function outer() { |
+ let stored = null; |
+ |
+ class C { |
+ [stored = arguments] = 0; |
+ } |
+ |
+ assertEquals(arguments, stored); |
+ } |
+ |
+ outer(); |
+} |
+ |
+ |
+// ctor params |
+{ |
+ let b = 0; |
+ class C { |
+ a = b; |
+ |
+ constructor(b) {} |
+ } |
+ |
+ let c = new C(1); |
+ assertEquals(0, c.a); |
+} |
+ |
+// class declaration name |
+{ |
+ class C { |
+ a = C; |
+ } |
+ let stored_class = C; |
+ C = null; |
+ |
+ let c = new stored_class; |
+ assertEquals(stored_class, c.a); |
+} |
+ |
+{ |
+ class C { |
+ static a = () => C; |
+ } |
+ let stored_class = C; |
+ C = null; |
+ |
+ assertEquals(stored_class, stored_class.a()); |
+} |
+ |
+{ |
+ let stored = null; |
+ |
+ class C { |
+ [stored = () => C] = 0; |
+ } |
+ let stored_class = C; |
+ C = null; |
+ |
+ assertEquals(stored_class, stored()); |
+} |
+ |
+{ |
+ assertThrows(() => { |
+ class C { |
+ static a = C; |
+ } |
+ }, ReferenceError); |
+} |
+ |
+{ |
+ assertThrows(() => { |
+ class C { |
+ [C] = 0; |
+ } |
+ }, ReferenceError); |
+} |
+ |
+// class expression name |
+{ |
+ let C = null; |
+ let stored_class = class C { |
+ a = C; |
+ } |
+ |
+ let c = new stored_class; |
+ assertEquals(stored_class, c.a); |
+} |
+ |
+{ |
+ let C = null; |
+ let stored_class = class C { |
+ static a = () => C; |
+ } |
+ |
+ assertEquals(stored_class, stored_class.a()); |
+} |
+ |
+{ |
+ let C = null; |
+ let stored = null; |
+ |
+ let stored_class = class C { |
+ [stored = () => C] = 0; |
+ }; |
+ |
+ assertEquals(stored_class, stored()); |
+} |
+ |
+{ |
+ assertThrows(() => ( |
+ class C { |
+ static a = C; |
+ } |
+ ), ReferenceError); |
+} |
+ |
+{ |
+ assertThrows(() => ( |
+ class C { |
+ [C] = 0; |
+ } |
+ ), ReferenceError); |
+} |