summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/parser/columnNumber.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/jit-test/tests/parser/columnNumber.js')
-rw-r--r--js/src/jit-test/tests/parser/columnNumber.js52
1 files changed, 52 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/parser/columnNumber.js b/js/src/jit-test/tests/parser/columnNumber.js
new file mode 100644
index 0000000000..051212c76b
--- /dev/null
+++ b/js/src/jit-test/tests/parser/columnNumber.js
@@ -0,0 +1,52 @@
+// Simple tests for evaluate's "columnNumber" option.
+
+load(libdir + 'asserts.js');
+
+assertEq(evaluate("saveStack().column"), 1);
+assertEq(evaluate("saveStack().column", { columnNumber: 1729 }), 1730);
+assertEq(evaluate("\nsaveStack().column", { columnNumber: 1729 }), 1);
+assertEq(evaluate("saveStack().column", { columnNumber: "42" }), 43);
+assertThrowsInstanceOf(() => evaluate("saveStack().column", { columnNumber: -10 }),
+ RangeError);
+assertThrowsInstanceOf(() => evaluate("saveStack().column", { columnNumber: Math.pow(2,30) }),
+ RangeError);
+
+if (helperThreadCount() > 0) {
+ print("offThreadCompileToStencil 1");
+ offThreadCompileToStencil("saveStack().column", { columnNumber: -10 });
+ assertThrowsInstanceOf(() => {
+ var stencil = finishOffThreadStencil();
+ evalStencil(stencil);
+ }, RangeError);
+
+ print("offThreadCompileToStencil 2");
+ offThreadCompileToStencil("saveStack().column", { columnNumber: Math.pow(2,30) });
+ assertThrowsInstanceOf(() => {
+ var stencil = finishOffThreadStencil();
+ evalStencil();
+ }, RangeError);
+
+ print("offThreadCompileToStencil 3");
+ offThreadCompileToStencil("saveStack().column", { columnNumber: 10000 });
+ stencil = finishOffThreadStencil();
+ assertEq(evalStencil(stencil), 10001);
+}
+
+// Check handling of columns near the limit of our ability to represent them.
+// (This is hardly thorough, but since web content can't set column numbers,
+// it's probably not worth it to be thorough.)
+const maxColumn = Math.pow(2, 30) - 1;
+assertEq(evaluate("saveStack().column", { columnNumber: maxColumn }),
+ maxColumn + 1);
+
+// Check the saturation behavior when we reach the limit of the column
+// representation.
+assertEq(evaluate(" saveStack().column", { columnNumber: maxColumn }),
+ maxColumn + 1);
+
+// Gathering source text for inclusion in error messages should not try to reach
+// outside the buffer to find the start of the source line. The below should
+// report the error without crashing.
+assertThrowsInstanceOf(() => evaluate("function x(y,y) { 'use strict'; } x()",
+ { columnNumber: 10 }),
+ SyntaxError);