summaryrefslogtreecommitdiffstats
path: root/js/src/tests/non262/JSON/parse-reviver.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/src/tests/non262/JSON/parse-reviver.js')
-rw-r--r--js/src/tests/non262/JSON/parse-reviver.js45
1 files changed, 45 insertions, 0 deletions
diff --git a/js/src/tests/non262/JSON/parse-reviver.js b/js/src/tests/non262/JSON/parse-reviver.js
new file mode 100644
index 0000000000..41e3daf704
--- /dev/null
+++ b/js/src/tests/non262/JSON/parse-reviver.js
@@ -0,0 +1,45 @@
+function doubler(k, v)
+{
+ assertEq(typeof k, "string");
+
+ if (typeof v == "number")
+ return 2 * v;
+
+ return v;
+}
+
+var x = JSON.parse('{"a":5,"b":6}', doubler);
+assertEq(x.hasOwnProperty('a'), true);
+assertEq(x.hasOwnProperty('b'), true);
+assertEq(x.a, 10);
+assertEq(x.b, 12);
+
+x = JSON.parse('[3, 4, 5]', doubler);
+assertEq(x[0], 6);
+assertEq(x[1], 8);
+assertEq(x[2], 10);
+
+// make sure reviver isn't called after a failed parse
+var called = false;
+function dontCallMe(k, v)
+{
+ called = true;
+}
+
+try
+{
+ JSON.parse('{{{{{{{}}}}', dontCallMe);
+ throw new Error("didn't throw?");
+}
+catch (e)
+{
+ assertEq(e instanceof SyntaxError, true, "wrong exception: " + e);
+}
+assertEq(called, false);
+
+/******************************************************************************/
+
+if (typeof reportCompare === "function")
+ reportCompare(true, true);
+
+print("Tests complete");