Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
Download
80684 views
1
// This is modified from Mozilla Reflect.parse test suite (the file is located
2
// at js/src/tests/js1_8_5/extensions/reflect-parse.js in the source tree).
3
//
4
// Some notable changes:
5
// * Removed unsupported features (destructuring, let, comprehensions...).
6
// * Removed tests for E4X (ECMAScript for XML).
7
// * Removed everything related to builder.
8
// * Enclosed every 'Pattern' construct with a scope.
9
// * Tweaked some expected tree to remove generator field.
10
// * Removed the test for bug 632030 and bug 632024.
11
12
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
13
/*
14
* Any copyright is dedicated to the Public Domain.
15
* http://creativecommons.org/licenses/publicdomain/
16
*/
17
18
(function (exports) {
19
20
function testReflect(Reflect, Pattern) {
21
22
function program(elts) { return Pattern({ type: "Program", body: elts }); }
23
function exprStmt(expr) { return Pattern({ type: "ExpressionStatement", expression: expr }); }
24
function throwStmt(expr) { return Pattern({ type: "ThrowStatement", argument: expr }); }
25
function returnStmt(expr) { return Pattern({ type: "ReturnStatement", argument: expr }); }
26
function yieldExpr(expr) { return Pattern({ type: "YieldExpression", argument: expr }); }
27
function lit(val) { return Pattern({ type: "Literal", value: val }); }
28
var thisExpr = Pattern({ type: "ThisExpression" });
29
function funDecl(id, params, body) { return Pattern({ type: "FunctionDeclaration",
30
id: id,
31
params: params,
32
defaults: [],
33
body: body,
34
generator: false,
35
expression: false
36
}); }
37
function genFunDecl(id, params, body) { return Pattern({ type: "FunctionDeclaration",
38
id: id,
39
params: params,
40
defaults: [],
41
body: body,
42
generator: false,
43
expression: false
44
}); }
45
function declarator(id, init) { return Pattern({ type: "VariableDeclarator", id: id, init: init }); }
46
function varDecl(decls) { return Pattern({ type: "VariableDeclaration", declarations: decls, kind: "var" }); }
47
function letDecl(decls) { return Pattern({ type: "VariableDeclaration", declarations: decls, kind: "let" }); }
48
function constDecl(decls) { return Pattern({ type: "VariableDeclaration", declarations: decls, kind: "const" }); }
49
function ident(name) { return Pattern({ type: "Identifier", name: name }); }
50
function dotExpr(obj, id) { return Pattern({ type: "MemberExpression", computed: false, object: obj, property: id }); }
51
function memExpr(obj, id) { return Pattern({ type: "MemberExpression", computed: true, object: obj, property: id }); }
52
function forStmt(init, test, update, body) { return Pattern({ type: "ForStatement", init: init, test: test, update: update, body: body }); }
53
function forInStmt(lhs, rhs, body) { return Pattern({ type: "ForInStatement", left: lhs, right: rhs, body: body, each: false }); }
54
function forEachInStmt(lhs, rhs, body) { return Pattern({ type: "ForInStatement", left: lhs, right: rhs, body: body, each: true }); }
55
function breakStmt(lab) { return Pattern({ type: "BreakStatement", label: lab }); }
56
function continueStmt(lab) { return Pattern({ type: "ContinueStatement", label: lab }); }
57
function blockStmt(body) { return Pattern({ type: "BlockStatement", body: body }); }
58
var emptyStmt = Pattern({ type: "EmptyStatement" });
59
function ifStmt(test, cons, alt) { return Pattern({ type: "IfStatement", test: test, alternate: alt, consequent: cons }); }
60
function labStmt(lab, stmt) { return Pattern({ type: "LabeledStatement", label: lab, body: stmt }); }
61
function withStmt(obj, stmt) { return Pattern({ type: "WithStatement", object: obj, body: stmt }); }
62
function whileStmt(test, stmt) { return Pattern({ type: "WhileStatement", test: test, body: stmt }); }
63
function doStmt(stmt, test) { return Pattern({ type: "DoWhileStatement", test: test, body: stmt }); }
64
function switchStmt(disc, cases) { return Pattern({ type: "SwitchStatement", discriminant: disc, cases: cases }); }
65
function caseClause(test, stmts) { return Pattern({ type: "SwitchCase", test: test, consequent: stmts }); }
66
function defaultClause(stmts) { return Pattern({ type: "SwitchCase", test: null, consequent: stmts }); }
67
function catchClause(id, guard, body) { if (guard) { return Pattern({ type: "GuardedCatchClause", param: id, guard: guard, body: body }) } else { return Pattern({ type: "CatchClause", param: id, body: body }); } }
68
function tryStmt(body, guarded, catches, fin) { return Pattern({ type: "TryStatement", block: body, guardedHandlers: guarded, handlers: catches, handler: (catches.length > 0) ? catches[0] : null, finalizer: fin }); }
69
function letStmt(head, body) { return Pattern({ type: "LetStatement", head: head, body: body }); }
70
function funExpr(id, args, body, gen) { return Pattern({ type: "FunctionExpression",
71
id: id,
72
params: args,
73
defaults: [],
74
body: body,
75
generator: false,
76
expression: false
77
}); }
78
function genFunExpr(id, args, body) { return Pattern({ type: "FunctionExpression",
79
id: id,
80
params: args,
81
defaults: [],
82
body: body,
83
generator: false,
84
expression: false
85
}); }
86
87
function unExpr(op, arg) { return Pattern({ type: "UnaryExpression", operator: op, argument: arg, prefix: true }); }
88
function binExpr(op, left, right) { return Pattern({ type: "BinaryExpression", operator: op, left: left, right: right }); }
89
function aExpr(op, left, right) { return Pattern({ type: "AssignmentExpression", operator: op, left: left, right: right }); }
90
function updExpr(op, arg, prefix) { return Pattern({ type: "UpdateExpression", operator: op, argument: arg, prefix: prefix }); }
91
function logExpr(op, left, right) { return Pattern({ type: "LogicalExpression", operator: op, left: left, right: right }); }
92
93
function condExpr(test, cons, alt) { return Pattern({ type: "ConditionalExpression", test: test, consequent: cons, alternate: alt }); }
94
function seqExpr(exprs) { return Pattern({ type: "SequenceExpression", expressions: exprs }); }
95
function newExpr(callee, args) { return Pattern({ type: "NewExpression", callee: callee, arguments: args }); }
96
function callExpr(callee, args) { return Pattern({ type: "CallExpression", callee: callee, arguments: args }); }
97
function arrExpr(elts) { return Pattern({ type: "ArrayExpression", elements: elts }); }
98
function objExpr(elts) { return Pattern({ type: "ObjectExpression", properties: elts }); }
99
function objProp(key, value, kind) { return Pattern({ type: "Property", key: key, computed: false, value: value, kind: kind, method: false, shorthand: false }); }
100
101
function arrPatt(elts) { return Pattern({ type: "ArrayPattern", elements: elts }); }
102
function objPatt(elts) { return Pattern({ type: "ObjectPattern", properties: elts }); }
103
104
function localSrc(src) { return "(function(){ " + src + " })"; }
105
function localPatt(patt) { return program([exprStmt(funExpr(null, [], blockStmt([patt])))]); }
106
function blockSrc(src) { return "(function(){ { " + src + " } })"; }
107
function blockPatt(patt) { return program([exprStmt(funExpr(null, [], blockStmt([blockStmt([patt])])))]); }
108
109
function assertBlockStmt(src, patt) {
110
blockPatt(patt).assert(Reflect.parse(blockSrc(src)));
111
}
112
113
function assertBlockExpr(src, patt) {
114
assertBlockStmt(src, exprStmt(patt));
115
}
116
117
function assertBlockDecl(src, patt, builder) {
118
blockPatt(patt).assert(Reflect.parse(blockSrc(src), {builder: builder}));
119
}
120
121
function assertLocalStmt(src, patt) {
122
localPatt(patt).assert(Reflect.parse(localSrc(src)));
123
}
124
125
function assertLocalExpr(src, patt) {
126
assertLocalStmt(src, exprStmt(patt));
127
}
128
129
function assertLocalDecl(src, patt) {
130
localPatt(patt).assert(Reflect.parse(localSrc(src)));
131
}
132
133
function assertGlobalStmt(src, patt, builder) {
134
program([patt]).assert(Reflect.parse(src, {builder: builder}));
135
}
136
137
function assertGlobalExpr(src, patt, builder) {
138
program([exprStmt(patt)]).assert(Reflect.parse(src, {builder: builder}));
139
//assertStmt(src, exprStmt(patt));
140
}
141
142
function assertGlobalDecl(src, patt) {
143
program([patt]).assert(Reflect.parse(src));
144
}
145
146
function assertProg(src, patt) {
147
program(patt).assert(Reflect.parse(src));
148
}
149
150
function assertStmt(src, patt) {
151
assertLocalStmt(src, patt);
152
assertGlobalStmt(src, patt);
153
assertBlockStmt(src, patt);
154
}
155
156
function assertExpr(src, patt) {
157
assertLocalExpr(src, patt);
158
assertGlobalExpr(src, patt);
159
assertBlockExpr(src, patt);
160
}
161
162
function assertDecl(src, patt) {
163
assertLocalDecl(src, patt);
164
assertGlobalDecl(src, patt);
165
assertBlockDecl(src, patt);
166
}
167
168
function assertError(src, errorType) {
169
try {
170
Reflect.parse(src);
171
} catch (e) {
172
return;
173
}
174
throw new Error("expected " + errorType.name + " for " + uneval(src));
175
}
176
177
178
// general tests
179
180
// NB: These are useful but for now jit-test doesn't do I/O reliably.
181
182
//program(_).assert(Reflect.parse(snarf('data/flapjax.txt')));
183
//program(_).assert(Reflect.parse(snarf('data/jquery-1.4.2.txt')));
184
//program(_).assert(Reflect.parse(snarf('data/prototype.js')));
185
//program(_).assert(Reflect.parse(snarf('data/dojo.js.uncompressed.js')));
186
//program(_).assert(Reflect.parse(snarf('data/mootools-1.2.4-core-nc.js')));
187
188
189
// declarations
190
191
assertDecl("var x = 1, y = 2, z = 3",
192
varDecl([declarator(ident("x"), lit(1)),
193
declarator(ident("y"), lit(2)),
194
declarator(ident("z"), lit(3))]));
195
assertDecl("var x, y, z",
196
varDecl([declarator(ident("x"), null),
197
declarator(ident("y"), null),
198
declarator(ident("z"), null)]));
199
assertDecl("function foo() { }",
200
funDecl(ident("foo"), [], blockStmt([])));
201
assertDecl("function foo() { return 42 }",
202
funDecl(ident("foo"), [], blockStmt([returnStmt(lit(42))])));
203
204
205
// Bug 591437: rebound args have their defs turned into uses
206
assertDecl("function f(a) { function a() { } }",
207
funDecl(ident("f"), [ident("a")], blockStmt([funDecl(ident("a"), [], blockStmt([]))])));
208
assertDecl("function f(a,b,c) { function b() { } }",
209
funDecl(ident("f"), [ident("a"),ident("b"),ident("c")], blockStmt([funDecl(ident("b"), [], blockStmt([]))])));
210
211
// expressions
212
213
assertExpr("true", lit(true));
214
assertExpr("false", lit(false));
215
assertExpr("42", lit(42));
216
assertExpr("(/asdf/)", lit(/asdf/));
217
assertExpr("this", thisExpr);
218
assertExpr("foo", ident("foo"));
219
assertExpr("foo.bar", dotExpr(ident("foo"), ident("bar")));
220
assertExpr("foo[bar]", memExpr(ident("foo"), ident("bar")));
221
assertExpr("(function(){})", funExpr(null, [], blockStmt([])));
222
assertExpr("(function f() {})", funExpr(ident("f"), [], blockStmt([])));
223
assertExpr("(function f(x,y,z) {})", funExpr(ident("f"), [ident("x"),ident("y"),ident("z")], blockStmt([])));
224
assertExpr("(++x)", updExpr("++", ident("x"), true));
225
assertExpr("(x++)", updExpr("++", ident("x"), false));
226
assertExpr("(+x)", unExpr("+", ident("x")));
227
assertExpr("(-x)", unExpr("-", ident("x")));
228
assertExpr("(!x)", unExpr("!", ident("x")));
229
assertExpr("(~x)", unExpr("~", ident("x")));
230
assertExpr("(delete x)", unExpr("delete", ident("x")));
231
assertExpr("(typeof x)", unExpr("typeof", ident("x")));
232
assertExpr("(void x)", unExpr("void", ident("x")));
233
assertExpr("(x == y)", binExpr("==", ident("x"), ident("y")));
234
assertExpr("(x != y)", binExpr("!=", ident("x"), ident("y")));
235
assertExpr("(x === y)", binExpr("===", ident("x"), ident("y")));
236
assertExpr("(x !== y)", binExpr("!==", ident("x"), ident("y")));
237
assertExpr("(x < y)", binExpr("<", ident("x"), ident("y")));
238
assertExpr("(x <= y)", binExpr("<=", ident("x"), ident("y")));
239
assertExpr("(x > y)", binExpr(">", ident("x"), ident("y")));
240
assertExpr("(x >= y)", binExpr(">=", ident("x"), ident("y")));
241
assertExpr("(x << y)", binExpr("<<", ident("x"), ident("y")));
242
assertExpr("(x >> y)", binExpr(">>", ident("x"), ident("y")));
243
assertExpr("(x >>> y)", binExpr(">>>", ident("x"), ident("y")));
244
assertExpr("(x + y)", binExpr("+", ident("x"), ident("y")));
245
assertExpr("(w + x + y + z)", binExpr("+", binExpr("+", binExpr("+", ident("w"), ident("x")), ident("y")), ident("z")));
246
assertExpr("(x - y)", binExpr("-", ident("x"), ident("y")));
247
assertExpr("(w - x - y - z)", binExpr("-", binExpr("-", binExpr("-", ident("w"), ident("x")), ident("y")), ident("z")));
248
assertExpr("(x * y)", binExpr("*", ident("x"), ident("y")));
249
assertExpr("(x / y)", binExpr("/", ident("x"), ident("y")));
250
assertExpr("(x % y)", binExpr("%", ident("x"), ident("y")));
251
assertExpr("(x | y)", binExpr("|", ident("x"), ident("y")));
252
assertExpr("(x ^ y)", binExpr("^", ident("x"), ident("y")));
253
assertExpr("(x & y)", binExpr("&", ident("x"), ident("y")));
254
assertExpr("(x in y)", binExpr("in", ident("x"), ident("y")));
255
assertExpr("(x instanceof y)", binExpr("instanceof", ident("x"), ident("y")));
256
assertExpr("(x = y)", aExpr("=", ident("x"), ident("y")));
257
assertExpr("(x += y)", aExpr("+=", ident("x"), ident("y")));
258
assertExpr("(x -= y)", aExpr("-=", ident("x"), ident("y")));
259
assertExpr("(x *= y)", aExpr("*=", ident("x"), ident("y")));
260
assertExpr("(x /= y)", aExpr("/=", ident("x"), ident("y")));
261
assertExpr("(x %= y)", aExpr("%=", ident("x"), ident("y")));
262
assertExpr("(x <<= y)", aExpr("<<=", ident("x"), ident("y")));
263
assertExpr("(x >>= y)", aExpr(">>=", ident("x"), ident("y")));
264
assertExpr("(x >>>= y)", aExpr(">>>=", ident("x"), ident("y")));
265
assertExpr("(x |= y)", aExpr("|=", ident("x"), ident("y")));
266
assertExpr("(x ^= y)", aExpr("^=", ident("x"), ident("y")));
267
assertExpr("(x &= y)", aExpr("&=", ident("x"), ident("y")));
268
assertExpr("(x || y)", logExpr("||", ident("x"), ident("y")));
269
assertExpr("(x && y)", logExpr("&&", ident("x"), ident("y")));
270
assertExpr("(w || x || y || z)", logExpr("||", logExpr("||", logExpr("||", ident("w"), ident("x")), ident("y")), ident("z")));
271
assertExpr("(x ? y : z)", condExpr(ident("x"), ident("y"), ident("z")));
272
assertExpr("(x,y)", seqExpr([ident("x"),ident("y")]));
273
assertExpr("(x,y,z)", seqExpr([ident("x"),ident("y"),ident("z")]));
274
assertExpr("(a,b,c,d,e,f,g)", seqExpr([ident("a"),ident("b"),ident("c"),ident("d"),ident("e"),ident("f"),ident("g")]));
275
assertExpr("(new Object)", newExpr(ident("Object"), []));
276
assertExpr("(new Object())", newExpr(ident("Object"), []));
277
assertExpr("(new Object(42))", newExpr(ident("Object"), [lit(42)]));
278
assertExpr("(new Object(1,2,3))", newExpr(ident("Object"), [lit(1),lit(2),lit(3)]));
279
assertExpr("(String())", callExpr(ident("String"), []));
280
assertExpr("(String(42))", callExpr(ident("String"), [lit(42)]));
281
assertExpr("(String(1,2,3))", callExpr(ident("String"), [lit(1),lit(2),lit(3)]));
282
assertExpr("[]", arrExpr([]));
283
assertExpr("[1]", arrExpr([lit(1)]));
284
assertExpr("[1,2]", arrExpr([lit(1),lit(2)]));
285
assertExpr("[1,2,3]", arrExpr([lit(1),lit(2),lit(3)]));
286
assertExpr("[1,,2,3]", arrExpr([lit(1),,lit(2),lit(3)]));
287
assertExpr("[1,,,2,3]", arrExpr([lit(1),,,lit(2),lit(3)]));
288
assertExpr("[1,,,2,,3]", arrExpr([lit(1),,,lit(2),,lit(3)]));
289
assertExpr("[1,,,2,,,3]", arrExpr([lit(1),,,lit(2),,,lit(3)]));
290
assertExpr("[,1,2,3]", arrExpr([,lit(1),lit(2),lit(3)]));
291
assertExpr("[,,1,2,3]", arrExpr([,,lit(1),lit(2),lit(3)]));
292
assertExpr("[,,,1,2,3]", arrExpr([,,,lit(1),lit(2),lit(3)]));
293
assertExpr("[,,,1,2,3,]", arrExpr([,,,lit(1),lit(2),lit(3)]));
294
assertExpr("[,,,1,2,3,,]", arrExpr([,,,lit(1),lit(2),lit(3),undefined]));
295
assertExpr("[,,,1,2,3,,,]", arrExpr([,,,lit(1),lit(2),lit(3),undefined,undefined]));
296
assertExpr("[,,,,,]", arrExpr([undefined,undefined,undefined,undefined,undefined]));
297
assertExpr("({})", objExpr([]));
298
assertExpr("({x:1})", objExpr([objProp(ident("x"), lit(1), "init")]));
299
assertExpr("({x:1, y:2})", objExpr([objProp(ident("x"), lit(1), "init"),
300
objProp(ident("y"), lit(2), "init")]));
301
assertExpr("({x:1, y:2, z:3})", objExpr([objProp(ident("x"), lit(1), "init"),
302
objProp(ident("y"), lit(2), "init"),
303
objProp(ident("z"), lit(3), "init") ]));
304
assertExpr("({x:1, 'y':2, z:3})", objExpr([objProp(ident("x"), lit(1), "init"),
305
objProp(lit("y"), lit(2), "init"),
306
objProp(ident("z"), lit(3), "init") ]));
307
assertExpr("({'x':1, 'y':2, z:3})", objExpr([objProp(lit("x"), lit(1), "init"),
308
objProp(lit("y"), lit(2), "init"),
309
objProp(ident("z"), lit(3), "init") ]));
310
assertExpr("({'x':1, 'y':2, 3:3})", objExpr([objProp(lit("x"), lit(1), "init"),
311
objProp(lit("y"), lit(2), "init"),
312
objProp(lit(3), lit(3), "init") ]));
313
314
// Bug 571617: eliminate constant-folding
315
assertExpr("2 + 3", binExpr("+", lit(2), lit(3)));
316
317
// Bug 632026: constant-folding
318
assertExpr("typeof(0?0:a)", unExpr("typeof", condExpr(lit(0), lit(0), ident("a"))));
319
320
// Bug 632056: constant-folding
321
program([exprStmt(ident("f")),
322
ifStmt(lit(1),
323
funDecl(ident("f"), [], blockStmt([])),
324
null)]).assert(Reflect.parse("f; if (1) function f(){}"));
325
326
// statements
327
328
assertStmt("throw 42", throwStmt(lit(42)));
329
assertStmt("for (;;) break", forStmt(null, null, null, breakStmt(null)));
330
assertStmt("for (x; y; z) break", forStmt(ident("x"), ident("y"), ident("z"), breakStmt(null)));
331
assertStmt("for (var x; y; z) break", forStmt(varDecl([declarator(ident("x"), null)]), ident("y"), ident("z"), breakStmt(null)));
332
assertStmt("for (var x = 42; y; z) break", forStmt(varDecl([declarator(ident("x"), lit(42))]), ident("y"), ident("z"), breakStmt(null)));
333
assertStmt("for (x; ; z) break", forStmt(ident("x"), null, ident("z"), breakStmt(null)));
334
assertStmt("for (var x; ; z) break", forStmt(varDecl([declarator(ident("x"), null)]), null, ident("z"), breakStmt(null)));
335
assertStmt("for (var x = 42; ; z) break", forStmt(varDecl([declarator(ident("x"), lit(42))]), null, ident("z"), breakStmt(null)));
336
assertStmt("for (x; y; ) break", forStmt(ident("x"), ident("y"), null, breakStmt(null)));
337
assertStmt("for (var x; y; ) break", forStmt(varDecl([declarator(ident("x"), null)]), ident("y"), null, breakStmt(null)));
338
assertStmt("for (var x = 42; y; ) break", forStmt(varDecl([declarator(ident("x"),lit(42))]), ident("y"), null, breakStmt(null)));
339
assertStmt("for (var x in y) break", forInStmt(varDecl([declarator(ident("x"),null)]), ident("y"), breakStmt(null)));
340
assertStmt("for (x in y) break", forInStmt(ident("x"), ident("y"), breakStmt(null)));
341
assertStmt("{ }", blockStmt([]));
342
assertStmt("{ throw 1; throw 2; throw 3; }", blockStmt([ throwStmt(lit(1)), throwStmt(lit(2)), throwStmt(lit(3))]));
343
assertStmt(";", emptyStmt);
344
assertStmt("if (foo) throw 42;", ifStmt(ident("foo"), throwStmt(lit(42)), null));
345
assertStmt("if (foo) throw 42; else true;", ifStmt(ident("foo"), throwStmt(lit(42)), exprStmt(lit(true))));
346
assertStmt("if (foo) { throw 1; throw 2; throw 3; }",
347
ifStmt(ident("foo"),
348
blockStmt([throwStmt(lit(1)), throwStmt(lit(2)), throwStmt(lit(3))]),
349
null));
350
assertStmt("if (foo) { throw 1; throw 2; throw 3; } else true;",
351
ifStmt(ident("foo"),
352
blockStmt([throwStmt(lit(1)), throwStmt(lit(2)), throwStmt(lit(3))]),
353
exprStmt(lit(true))));
354
assertStmt("foo: for(;;) break foo;", labStmt(ident("foo"), forStmt(null, null, null, breakStmt(ident("foo")))));
355
assertStmt("foo: for(;;) continue foo;", labStmt(ident("foo"), forStmt(null, null, null, continueStmt(ident("foo")))));
356
assertStmt("with (obj) { }", withStmt(ident("obj"), blockStmt([])));
357
assertStmt("with (obj) { obj; }", withStmt(ident("obj"), blockStmt([exprStmt(ident("obj"))])));
358
assertStmt("while (foo) { }", whileStmt(ident("foo"), blockStmt([])));
359
assertStmt("while (foo) { foo; }", whileStmt(ident("foo"), blockStmt([exprStmt(ident("foo"))])));
360
assertStmt("do { } while (foo);", doStmt(blockStmt([]), ident("foo")));
361
assertStmt("do { foo; } while (foo)", doStmt(blockStmt([exprStmt(ident("foo"))]), ident("foo")));
362
assertStmt("switch (foo) { case 1: 1; break; case 2: 2; break; default: 3; }",
363
switchStmt(ident("foo"),
364
[ caseClause(lit(1), [ exprStmt(lit(1)), breakStmt(null) ]),
365
caseClause(lit(2), [ exprStmt(lit(2)), breakStmt(null) ]),
366
defaultClause([ exprStmt(lit(3)) ]) ]));
367
assertStmt("switch (foo) { case 1: 1; break; case 2: 2; break; default: 3; case 42: 42; }",
368
switchStmt(ident("foo"),
369
[ caseClause(lit(1), [ exprStmt(lit(1)), breakStmt(null) ]),
370
caseClause(lit(2), [ exprStmt(lit(2)), breakStmt(null) ]),
371
defaultClause([ exprStmt(lit(3)) ]),
372
caseClause(lit(42), [ exprStmt(lit(42)) ]) ]));
373
assertStmt("try { } catch (e) { }",
374
tryStmt(blockStmt([]),
375
[],
376
[ catchClause(ident("e"), null, blockStmt([])) ],
377
null));
378
assertStmt("try { } catch (e) { } finally { }",
379
tryStmt(blockStmt([]),
380
[],
381
[ catchClause(ident("e"), null, blockStmt([])) ],
382
blockStmt([])));
383
assertStmt("try { } finally { }",
384
tryStmt(blockStmt([]),
385
[],
386
[],
387
blockStmt([])));
388
389
// redeclarations (TOK_NAME nodes with lexdef)
390
391
assertStmt("function f() { function g() { } function g() { } }",
392
funDecl(ident("f"), [], blockStmt([funDecl(ident("g"), [], blockStmt([])),
393
funDecl(ident("g"), [], blockStmt([]))])));
394
395
assertStmt("function f() { function g() { } function g() { return 42 } }",
396
funDecl(ident("f"), [], blockStmt([funDecl(ident("g"), [], blockStmt([])),
397
funDecl(ident("g"), [], blockStmt([returnStmt(lit(42))]))])));
398
399
assertStmt("function f() { var x = 42; var x = 43; }",
400
funDecl(ident("f"), [], blockStmt([varDecl([declarator(ident("x"),lit(42))]),
401
varDecl([declarator(ident("x"),lit(43))])])));
402
403
// getters and setters
404
405
assertExpr("({ get x() { return 42 } })",
406
objExpr([ objProp(ident("x"),
407
funExpr(null, [], blockStmt([returnStmt(lit(42))])),
408
"get" ) ]));
409
assertExpr("({ set x(v) { return 42 } })",
410
objExpr([ objProp(ident("x"),
411
funExpr(null, [ident("v")], blockStmt([returnStmt(lit(42))])),
412
"set" ) ]));
413
414
}
415
416
exports.testReflect = testReflect;
417
418
}(typeof exports === 'undefined' ? this : exports));
419
420