summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/resist-fingerprinting
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan-asm.js56
-rw-r--r--js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan.js88
-rw-r--r--js/src/jit-test/tests/resist-fingerprinting/timezone.js33
3 files changed, 177 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan-asm.js b/js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan-asm.js
new file mode 100644
index 0000000000..9662a213d6
--- /dev/null
+++ b/js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan-asm.js
@@ -0,0 +1,56 @@
+// |jit-test| skip-if: !isAsmJSCompilationAvailable()
+
+load(libdir + "asm.js");
+
+var g = newGlobal({shouldResistFingerprinting: true})
+
+var code = (fun) => {
+ return `(function asm(glob) {
+ "use asm";
+ var sq=glob.Math.${fun}; function f(d) { d=+d; return +sq(d) } return f;
+ })`;
+}
+
+// Linking RFP asm.js with non-RFP Math.sin.
+let asmSin = g.eval(code("sin"));
+assertAsmLinkFail(asmSin, {Math: {sin: Math.sin}});
+
+// Linking RFP asm.js with RFP Math.sin
+const sin = asmLink(asmSin, {Math: {sin: g.Math.sin}});
+assertEq(sin(35*Math.LN2 ), -0.765996413898051);
+assertEq(sin(110*Math.LOG2E), 0.9989410140273757);
+assertEq(sin(7*Math.LOG10E ), 0.10135692924965616);
+
+// Linking non-RFP asm.js with RFP Math.sin
+asmSin = eval(code("sin"))
+assertAsmLinkFail(asmSin, {Math: {sin: g.Math.sin}});
+
+// Linking non-RFP asm.js with non-RFP Math.sin (the "normal case")
+asmLink(asmSin, {Math: {sin: Math.sin}});
+
+// Testing cos
+let asmCos = g.eval(code("cos"));
+assertAsmLinkFail(asmCos, {Math: {cos: Math.cos}});
+const cos = asmLink(asmCos, {Math: {cos: g.Math.cos}});
+assertEq(cos(1e130 ), -0.767224894221913);
+assertEq(cos(1e272 ), -0.7415825695514536);
+assertEq(cos(1e284 ), 0.7086865671674247);
+assertEq(cos(1e75 ), -0.7482651726250321);
+assertEq(cos(57*Math.E ), -0.536911695749024);
+assertEq(cos(21*Math.LN2 ), -0.4067775970251724);
+assertEq(cos(51*Math.LN2 ), -0.7017203400855446);
+assertEq(cos(21*Math.SQRT1_2), -0.6534063185820198);
+assertEq(cos(17*Math.LOG10E ), 0.4537557425982784);
+assertEq(cos(2*Math.LOG10E ), 0.6459044007438142);
+
+// Testing tan
+let asmTan = g.eval(code("tan"));
+assertAsmLinkFail(asmTan, {Math: {tan: Math.tan}});
+const tan = asmLink(asmTan, {Math: {tan: g.Math.tan}});
+assertEq(tan(1e140 ), 0.7879079967710036);
+assertEq(tan(6*Math.E ), 0.6866761546452431);
+assertEq(tan(6*Math.LN2 ), 1.6182817135715877);
+assertEq(tan(10*Math.LOG2E ), -3.3537128705376014);
+assertEq(tan(17*Math.SQRT2 ), -1.9222955461799982);
+assertEq(tan(34*Math.SQRT1_2), -1.9222955461799982);
+assertEq(tan(10*Math.LOG10E ), 2.5824856130712432);
diff --git a/js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan.js b/js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan.js
new file mode 100644
index 0000000000..30508ab576
--- /dev/null
+++ b/js/src/jit-test/tests/resist-fingerprinting/math-fdlibm-sincostan.js
@@ -0,0 +1,88 @@
+let g = newGlobal({shouldResistFingerprinting: true});
+
+// Adapted from https://github.com/arkenfox/TZP/blob/master/tests/math.html
+// Tests all values that differed from libm for me on Linux and Windows.
+
+function test() {
+ for (var i = 0; i < 100; i++) {
+ assertEq(g.Math.cos(1e130 ), -0.767224894221913);
+ assertEq(g.Math.cos(1e272 ), -0.7415825695514536);
+ assertEq(g.Math.cos(1e284 ), 0.7086865671674247);
+ assertEq(g.Math.cos(1e75 ), -0.7482651726250321);
+ assertEq(g.Math.cos(57*Math.E ), -0.536911695749024);
+ assertEq(g.Math.cos(21*Math.LN2 ), -0.4067775970251724);
+ assertEq(g.Math.cos(51*Math.LN2 ), -0.7017203400855446);
+ assertEq(g.Math.cos(21*Math.SQRT1_2), -0.6534063185820198);
+ assertEq(g.Math.cos(17*Math.LOG10E ), 0.4537557425982784);
+ assertEq(g.Math.cos(2*Math.LOG10E ), 0.6459044007438142);
+
+ assertEq(g.Math.sin(35*Math.LN2 ), -0.765996413898051);
+ assertEq(g.Math.sin(110*Math.LOG2E ), 0.9989410140273757);
+ assertEq(g.Math.sin(7*Math.LOG10E ), 0.10135692924965616);
+
+ assertEq(g.Math.tan(1e140 ), 0.7879079967710036);
+ assertEq(g.Math.tan(6*Math.E ), 0.6866761546452431);
+ assertEq(g.Math.tan(6*Math.LN2 ), 1.6182817135715877);
+ assertEq(g.Math.tan(10*Math.LOG2E ), -3.3537128705376014);
+ assertEq(g.Math.tan(17*Math.SQRT2 ), -1.9222955461799982);
+ assertEq(g.Math.tan(34*Math.SQRT1_2), -1.9222955461799982);
+ assertEq(g.Math.tan(10*Math.LOG10E ), 2.5824856130712432);
+ }
+}
+
+/*
+cos
+ 3: 1e130 : -0.767224894221913 ,
+ 4: 1e272 : -0.7415825695514536,
+ 6: 1e284 : 0.7086865671674247,
+ 7: 1e75 : -0.7482651726250321,
+ 13: 57*Math.E : -0.536911695749024,
+ 14: 21*Math.LN2 : -0.4067775970251724,
+ 15: 51*Math.LN2 : -0.7017203400855446,
+ 19: 21*Math.SQRT1_2 : -0.6534063185820198,
+ 20: 17*Math.LOG10E : 0.4537557425982784,
+ 21: 2*Math.LOG10E : 0.6459044007438142,
+
+
+sin
+ 11: : -0.765996413898051,
+ 12: : 0.9989410140273757,
+ 13: : 0.10135692924965616,
+
+tan
+ 1: 1e140 : 0.7879079967710036,
+ 10: 6*Math.E : 0.6866761546452431,
+ 11: 6*Math.LN2 : 1.6182817135715877,
+ 12: 10*Math.LOG2E : -3.3537128705376014,
+ 13: 17*Math.SQRT2 : -1.9222955461799982,
+ 14: 34*Math.SQRT1_2 : -1.9222955461799982,
+ 15: 10*Math.LOG10E : 2.5824856130712432,
+*/
+
+test();
+
+// Test if the test is still useful, or if all results match without
+// fingerprinting resistance as well.
+if (!getBuildConfiguration()["android"] &&
+ Math.cos(1e130 ) == -0.767224894221913 &&
+ Math.cos(1e272 ) == -0.7415825695514536 &&
+ Math.cos(1e284 ) == 0.7086865671674247 &&
+ Math.cos(1e75 ) == -0.7482651726250321 &&
+ Math.cos(57*Math.E ) == -0.536911695749024 &&
+ Math.cos(21*Math.LN2 ) == -0.4067775970251724 &&
+ Math.cos(51*Math.LN2 ) == -0.7017203400855446 &&
+ Math.cos(21*Math.SQRT1_2) == -0.6534063185820198 &&
+ Math.cos(17*Math.LOG10E ) == 0.4537557425982784 &&
+ Math.cos(2*Math.LOG10E ) == 0.6459044007438142 &&
+ Math.sin(35*Math.LN2 ) == -0.765996413898051 &&
+ Math.sin(110*Math.LOG2E ) == 0.9989410140273757 &&
+ Math.sin(7*Math.LOG10E ) == 0.10135692924965616 &&
+ Math.tan(1e140 ) == 0.7879079967710036 &&
+ Math.tan(6*Math.E ) == 0.6866761546452431 &&
+ Math.tan(6*Math.LN2 ) == 1.6182817135715877 &&
+ Math.tan(10*Math.LOG2E ) == -3.3537128705376014 &&
+ Math.tan(17*Math.SQRT2 ) == -1.9222955461799982 &&
+ Math.tan(34*Math.SQRT1_2) == -1.9222955461799982 &&
+ Math.tan(10*Math.LOG10E ) == 2.5824856130712432) {
+ assertEq(false, true);
+}
diff --git a/js/src/jit-test/tests/resist-fingerprinting/timezone.js b/js/src/jit-test/tests/resist-fingerprinting/timezone.js
new file mode 100644
index 0000000000..64e6f86eee
--- /dev/null
+++ b/js/src/jit-test/tests/resist-fingerprinting/timezone.js
@@ -0,0 +1,33 @@
+// |jit-test| tz-pacific; skip-if: typeof Intl === 'undefined'
+
+let tzRE = /\(([^\)]+)\)/;
+
+// Make sure we aren't already running with UTC
+let original = new Date(0);
+assertEq(tzRE.exec(original.toString())[1], "Pacific Standard Time");
+
+let originalDT = Intl.DateTimeFormat("en-US", {
+ dateStyle: "full",
+ timeStyle: "full",
+});
+assertEq(originalDT.format(original).endsWith("Pacific Standard Time"), true);
+assertEq(originalDT.resolvedOptions().timeZone, "PST8PDT");
+
+let global = newGlobal({shouldResistFingerprinting: true});
+
+let date = new global.Date();
+assertEq(tzRE.exec(date.toString())[1], "Coordinated Universal Time");
+assertEq(tzRE.exec(date.toTimeString())[1], "Coordinated Universal Time");
+assertEq(date.getFullYear(), date.getUTCFullYear());
+assertEq(date.getMonth(), date.getUTCMonth());
+assertEq(date.getDate(), date.getUTCDate());
+assertEq(date.getDay(), date.getUTCDay());
+assertEq(date.getHours(),date.getUTCHours());
+assertEq(date.getTimezoneOffset(), 0);
+
+let dt = global.Intl.DateTimeFormat("en-US", {
+ dateStyle: "full",
+ timeStyle: "full",
+});
+assertEq(dt.format(date).endsWith("Coordinated Universal Time"), true);
+assertEq(dt.resolvedOptions().timeZone, "UTC");