Skip to content

Commit 0489e12

Browse files
committed
Add Insight test for frame variables in a JS block scope.
1 parent 1349d16 commit 0489e12

File tree

3 files changed

+129
-0
lines changed

3 files changed

+129
-0
lines changed
Lines changed: 38 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,38 @@
1+
# Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
2+
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
3+
#
4+
# This code is free software; you can redistribute it and/or modify it
5+
# under the terms of the GNU General Public License version 2 only, as
6+
# published by the Free Software Foundation. Oracle designates this
7+
# particular file as subject to the "Classpath" exception as provided
8+
# by Oracle in the LICENSE file that accompanied this code.
9+
#
10+
# This code is distributed in the hope that it will be useful, but WITHOUT
11+
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12+
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
13+
# version 2 for more details (a copy is included in the LICENSE file that
14+
# accompanied this code).
15+
#
16+
# You should have received a copy of the GNU General Public License version
17+
# 2 along with this work; if not, write to the Free Software Foundation,
18+
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
19+
#
20+
# Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
21+
# or visit www.oracle.com if you need additional information or have any
22+
# questions.
23+
#
24+
> js --insight=blockscopeinsight.js blockscope.js
25+
=== on enter at sumEvenNumbers (blockscope.js:32) : {i=0, limit=5, sum=0}
26+
frame at sumEvenNumbers (blockscope.js:32) : {i=0, limit=5, sum=0}
27+
=== on leave at sumEvenNumbers (blockscope.js:32) : {i=0, limit=5, sum=0}
28+
frame at sumEvenNumbers (blockscope.js:32) : {i=0, limit=5, sum=0}
29+
=== on enter at sumEvenNumbers (blockscope.js:32) : {i=2, limit=5, sum=0}
30+
frame at sumEvenNumbers (blockscope.js:32) : {i=2, limit=5, sum=0}
31+
=== on leave at sumEvenNumbers (blockscope.js:32) : {i=2, limit=5, sum=2}
32+
frame at sumEvenNumbers (blockscope.js:32) : {i=2, limit=5, sum=2}
33+
=== on enter at sumEvenNumbers (blockscope.js:32) : {i=4, limit=5, sum=2}
34+
frame at sumEvenNumbers (blockscope.js:32) : {i=4, limit=5, sum=2}
35+
=== on leave at sumEvenNumbers (blockscope.js:32) : {i=4, limit=5, sum=6}
36+
frame at sumEvenNumbers (blockscope.js:32) : {i=4, limit=5, sum=6}
37+
=== on leave at sumEvenNumbers (blockscope.js:26) : {sum=6}
38+
6
Lines changed: 39 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
/*
2+
* Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation. Oracle designates this
8+
* particular file as subject to the "Classpath" exception as provided
9+
* by Oracle in the LICENSE file that accompanied this code.
10+
*
11+
* This code is distributed in the hope that it will be useful, but WITHOUT
12+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14+
* version 2 for more details (a copy is included in the LICENSE file that
15+
* accompanied this code).
16+
*
17+
* You should have received a copy of the GNU General Public License version
18+
* 2 along with this work; if not, write to the Free Software Foundation,
19+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20+
*
21+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22+
* or visit www.oracle.com if you need additional information or have any
23+
* questions.
24+
*/
25+
26+
function sumEvenNumbers() {
27+
let sum = 0;
28+
{
29+
const limit = 5;
30+
for (let i = 0; i < limit; i++) {
31+
if (i % 2 === 0) {
32+
sum += i;
33+
}
34+
}
35+
}
36+
return sum;
37+
}
38+
39+
console.log(sumEvenNumbers());
Lines changed: 52 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,52 @@
1+
/*
2+
* Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation. Oracle designates this
8+
* particular file as subject to the "Classpath" exception as provided
9+
* by Oracle in the LICENSE file that accompanied this code.
10+
*
11+
* This code is distributed in the hope that it will be useful, but WITHOUT
12+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14+
* version 2 for more details (a copy is included in the LICENSE file that
15+
* accompanied this code).
16+
*
17+
* You should have received a copy of the GNU General Public License version
18+
* 2 along with this work; if not, write to the Free Software Foundation,
19+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20+
*
21+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22+
* or visit www.oracle.com if you need additional information or have any
23+
* questions.
24+
*/
25+
26+
function dumpVars(vars) {
27+
return Object.entries(vars).filter(([name]) => name != "this").map(([name, value]) => `${name}=${value}`).join(", ");
28+
}
29+
30+
for (let [eventId, eventName = eventId] of [["enter"], ["return", "leave"]]) {
31+
insight.on(eventId, function(ctx, frame) {
32+
console.log(`=== on ${eventName} at ${ctx.name} (${ctx.source.name}:${ctx.line}) : {${dumpVars(frame)}}`);
33+
ctx.iterateFrames((at, frameVars) => {
34+
if (at.name.endsWith("sumEvenNumbers")) {
35+
console.log(` frame at ${at.name} (${at.source.name}:${at.line}) : {${dumpVars(frameVars)}}`);
36+
}
37+
});
38+
}, {
39+
statements: true,
40+
at: {
41+
sourcePath: ".*blockscope.*",
42+
line: 32,
43+
}
44+
});
45+
}
46+
47+
insight.on("return", function(ctx, frame) {
48+
console.log(`=== on leave at ${ctx.name} (${ctx.source.name}:${ctx.line}) : {${dumpVars(frame)}}`);
49+
}, {
50+
roots: true,
51+
rootNameFilter: "sumEvenNumbers",
52+
});

0 commit comments

Comments
 (0)