summaryrefslogtreecommitdiffstats
path: root/js/src/jit-test/tests/ion/mathRound.js
diff options
context:
space:
mode:
authorMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
committerMatt A. Tobin <mattatobin@localhost.localdomain>2018-02-02 04:16:08 -0500
commit5f8de423f190bbb79a62f804151bc24824fa32d8 (patch)
tree10027f336435511475e392454359edea8e25895d /js/src/jit-test/tests/ion/mathRound.js
parent49ee0794b5d912db1f95dce6eb52d781dc210db5 (diff)
downloadUXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.gz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.lz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.tar.xz
UXP-5f8de423f190bbb79a62f804151bc24824fa32d8.zip
Add m-esr52 at 52.6.0
Diffstat (limited to 'js/src/jit-test/tests/ion/mathRound.js')
-rw-r--r--js/src/jit-test/tests/ion/mathRound.js48
1 files changed, 48 insertions, 0 deletions
diff --git a/js/src/jit-test/tests/ion/mathRound.js b/js/src/jit-test/tests/ion/mathRound.js
new file mode 100644
index 000000000..7475a66be
--- /dev/null
+++ b/js/src/jit-test/tests/ion/mathRound.js
@@ -0,0 +1,48 @@
+// Test Math.round() for IonMonkey.
+// Requires --ion-eager to enter at the top of each loop.
+
+var roundDTests = [
+ [-0, -0],
+ [0.49999999999999997, 0],
+ [0.5, 1],
+ [1.0, 1],
+ [1.5, 2],
+ [792.8, 793],
+ [-0.1, -0],
+ [-1.0001, -1],
+ [-3.14, -3],
+ [2137483649.5, 2137483650],
+ [2137483648.5, 2137483649],
+ [2137483647.1, 2137483647],
+ [900000000000, 900000000000],
+ [-0, -0],
+ [-Infinity, -Infinity],
+ [Infinity, Infinity],
+ [NaN, NaN],
+ [-2147483648.8, -2147483649],
+ [-2147483649.8, -2147483650]
+];
+
+var roundITests = [
+ [0, 0],
+ [4, 4],
+ [2147483648, 2147483648],
+ [-2147483649, -2147483649]
+];
+
+// Typed functions to be compiled by Ion.
+function roundD(x) { return Math.round(x); }
+function roundI(x) { return Math.round(x); }
+
+function test() {
+ // Always run this function in the interpreter.
+ try {} catch (e) {}
+
+ for (var i = 0; i < roundDTests.length; i++)
+ assertEq(roundD(roundDTests[i][0]), roundDTests[i][1]);
+ for (var i = 0; i < roundITests.length; i++)
+ assertEq(roundI(roundITests[i][0]), roundITests[i][1]);
+}
+
+for (var i = 0; i < 40; i++)
+ test();