Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1291)

Side by Side Diff: test/mjsunit/es6/classes-proxy.js

Issue 1484473002: Fix Reflect.construct wrt proxy, generator, and non-subclass new.target (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 5 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « src/runtime/runtime-object.cc ('k') | test/mjsunit/harmony/reflect-construct.js » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 the V8 project authors. All rights reserved. 1 // Copyright 2015 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: --allow-natives-syntax --harmony-proxies --harmony-reflect 5 // Flags: --allow-natives-syntax --harmony-proxies --harmony-reflect
6 6
7 function CreateConstructableProxy(handler) { 7 function CreateConstructableProxy(handler) {
8 return Proxy.createFunction(handler, function() {}, function() {}); 8 return Proxy.createFunction(handler, function() {}, function() {});
9 } 9 }
10 10
(...skipping 21 matching lines...) Expand all
32 get(k) { 32 get(k) {
33 log.push("get trap"); 33 log.push("get trap");
34 return 10; 34 return 10;
35 }}); 35 }});
36 36
37 var o = Reflect.construct(Number, [100], proxy); 37 var o = Reflect.construct(Number, [100], proxy);
38 assertEquals(["get trap"], log); 38 assertEquals(["get trap"], log);
39 assertTrue(Object.getPrototypeOf(o) === Object.prototype); 39 assertTrue(Object.getPrototypeOf(o) === Object.prototype);
40 assertEquals(100, Number.prototype.valueOf.call(o)); 40 assertEquals(100, Number.prototype.valueOf.call(o));
41 })(); 41 })();
42
43 (function() {
44 var prototype = { x: 1 };
45 var log = [];
46
47 var proxy = CreateConstructableProxy({
48 get(k) {
49 log.push("get trap");
50 return prototype;
51 }});
52
53 var o = Reflect.construct(Function, ["return 1000"], proxy);
54 assertEquals(["get trap"], log);
55 assertTrue(Object.getPrototypeOf(o) === prototype);
56 assertEquals(1000, o());
57 })();
58
59 (function() {
60 var prototype = { x: 1 };
61 var log = [];
62
63 var proxy = CreateConstructableProxy({
64 get(k) {
65 log.push("get trap");
66 return prototype;
67 }});
68
69 var o = Reflect.construct(Array, [1, 2, 3], proxy);
70 assertEquals(["get trap"], log);
71 assertTrue(Object.getPrototypeOf(o) === prototype);
72 assertEquals([1, 2, 3], o);
73 })();
OLDNEW
« no previous file with comments | « src/runtime/runtime-object.cc ('k') | test/mjsunit/harmony/reflect-construct.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698