summaryrefslogtreecommitdiffstats
path: root/js/src/tests/js1_8_1/jit/regress-458838.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/js1_8_1/jit/regress-458838.js')
-rw-r--r--js/src/tests/js1_8_1/jit/regress-458838.js63
1 files changed, 63 insertions, 0 deletions
diff --git a/js/src/tests/js1_8_1/jit/regress-458838.js b/js/src/tests/js1_8_1/jit/regress-458838.js
new file mode 100644
index 000000000..b8b19f2d4
--- /dev/null
+++ b/js/src/tests/js1_8_1/jit/regress-458838.js
@@ -0,0 +1,63 @@
+/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
+/* This Source Code Form is subject to the terms of the Mozilla Public
+ * License, v. 2.0. If a copy of the MPL was not distributed with this
+ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
+
+//-----------------------------------------------------------------------------
+var BUGNUMBER = 458838;
+var summary = 'TM: do not fall off trace when nested function accesses var of outer function';
+var actual = '';
+var expect = '';
+
+//-----------------------------------------------------------------------------
+test();
+//-----------------------------------------------------------------------------
+
+function test()
+{
+ enterFunc ('test');
+ printBugNumber(BUGNUMBER);
+ printStatus (summary);
+
+
+ function f() {
+ var a = 1;
+ function g() {
+ var b = 0
+ for (var i = 0; i < 10; ++i) {
+ b += a;
+ }
+ return b;
+ }
+
+ return g();
+ }
+
+ expect = 10;
+ actual = f();
+
+ var recorderStarted;
+ var recorderAborted;
+ var traceCompleted;
+ var skip = true;
+
+ if (this.tracemonkey && !this.tracemonkey.adaptive)
+ {
+ recorderStarted = this.tracemonkey.recorderStarted;
+ recorderAborted = this.tracemonkey.recorderAborted;
+ traceCompleted = this.tracemonkey.traceCompleted;
+ skip = false;
+ }
+
+
+ reportCompare(expect, actual, summary + ': return value 10');
+
+ if (!skip)
+ {
+ expect = 'recorderStarted=1, recorderAborted=0, traceCompleted=1';
+ actual = 'recorderStarted=' + recorderStarted + ', recorderAborted=' + recorderAborted + ', traceCompleted=' + traceCompleted;
+ reportCompare(expect, actual, summary + ': trace');
+ }
+
+ exitFunc ('test');
+}