diff --git a/js/src/jit-test/tests/ion/bug1273858-1.js b/js/src/jit-test/tests/ion/bug1273858-1.js new file mode 100644 index 000000000000..89769ffe583f --- /dev/null +++ b/js/src/jit-test/tests/ion/bug1273858-1.js @@ -0,0 +1,53 @@ +// |jit-test| --no-threads + +function t1() { + let x = []; + + for (let k = 0; k < 100; ++k) + x[k] = () => k; // Lexical capture + + try { + eval("k"); + throw false; + } + catch (e) { + if (!(e instanceof ReferenceError)) + throw "Loop index escaped block"; + } + + for (var i = 0; i < 100; ++i) + if (x[i]() != i) + throw "Bad let capture"; +} +t1(); +t1(); +t1(); +t1(); + +function t2() { + let x = []; + let y = {}; + + for (var i = 0; i < 100; ++i) + x[i] = i; + + for (const k of x) + y[k] = () => k; // Lexical capture + + try { + eval("k"); + throw false; + } + catch (e) { + if (!(e instanceof ReferenceError)) + throw "Loop index escaped block"; + } + + for (var i = 0; i < 100; ++i) + if (y[i]() != i) + throw "Bad const capture"; +} +t2(); +t2(); +t2(); +t2(); diff --git a/js/src/jit-test/tests/ion/bug1273858-2.js b/js/src/jit-test/tests/ion/bug1273858-2.js new file mode 100644 index 000000000000..6d274cf02b95 --- /dev/null +++ b/js/src/jit-test/tests/ion/bug1273858-2.js @@ -0,0 +1,46 @@ +// |jit-test| --no-threads + +function t1() { + let x = []; + + try + { + for (let k = 0; k < 100; ++k) + { + let w = () => k; // Lexical capture + + if (w() > 10) + { + throw () => w; // Lexical capture + } + + x[k] = w; + } + } + catch (e) + { + // 'w' and 'k' should leave scope as exception unwinds + + try { + eval("k"); + throw false; + } + catch (e) { + if (!(e instanceof ReferenceError)) + throw "Loop index escaped block"; + } + + try { + eval("w"); + throw false; + } + catch (e) { + if (!(e instanceof ReferenceError)) + throw "Local name escaped block"; + } + } +} +t1(); +t1(); +t1(); +t1();