| // Copyright 2013 the V8 project authors. All rights reserved. |
| // Redistribution and use in source and binary forms, with or without |
| // modification, are permitted provided that the following conditions are |
| // met: |
| // |
| // * Redistributions of source code must retain the above copyright |
| // notice, this list of conditions and the following disclaimer. |
| // * Redistributions in binary form must reproduce the above |
| // copyright notice, this list of conditions and the following |
| // disclaimer in the documentation and/or other materials provided |
| // with the distribution. |
| // * Neither the name of Google Inc. nor the names of its |
| // contributors may be used to endorse or promote products derived |
| // from this software without specific prior written permission. |
| // |
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
| // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| |
| |
| // Flags: --allow-natives-syntax --nostress-opt --opt |
| // Flags: --no-stress-flush-bytecode |
| |
| function test(f, iterations) { |
| %PrepareFunctionForOptimization(f); |
| f(); |
| f(); |
| // Some of the tests need to learn until they stabilize. |
| let n = iterations ? iterations : 1; |
| for (let i = 0; i < n; i++) { |
| %OptimizeFunctionOnNextCall(f); |
| f(); |
| %PrepareFunctionForOptimization(f); |
| } |
| // Assert that the function finally stabilized. |
| assertOptimized(f); |
| } |
| |
| test(function add() { |
| assertEquals(2, 1 + 1); |
| assertEquals(2.5, 1.25 + 1.25); |
| assertSame(Infinity, Infinity + Infinity); |
| assertSame(Infinity, Infinity + 3); |
| assertSame(NaN, Infinity + (-Infinity)); |
| assertSame(NaN, NaN + 2); |
| assertSame(-Infinity, 1 / (-0.0 + (-0.0))); |
| assertSame(Infinity, 1 / (-0.0 + 0.0)); |
| }); |
| |
| test(function inc() { |
| var a = 1; |
| var b = Infinity; |
| var c = -Infinity; |
| var d = NaN; |
| assertEquals(2, ++a); |
| assertSame(Infinity, ++b); |
| assertSame(-Infinity, ++c); |
| assertSame(NaN, ++d); |
| }); |
| |
| test(function dec() { |
| var a = 1; |
| var b = Infinity; |
| var c = -Infinity; |
| var d = NaN; |
| assertEquals(0, --a); |
| assertSame(Infinity, --b); |
| assertSame(-Infinity, --c); |
| assertSame(NaN, --d); |
| }); |
| |
| test(function sub() { |
| assertEquals(0, 1 - 1); |
| assertEquals(0.5, 1.5 - 1); |
| assertSame(Infinity, Infinity - (-Infinity)); |
| assertSame(Infinity, Infinity - 3); |
| assertSame(NaN, Infinity - Infinity); |
| assertSame(NaN, NaN - 2); |
| assertSame(-Infinity, 1 / (-0.0 - 0.0)); |
| assertSame(Infinity, 1 / (0.0 - 0.0)); |
| }); |
| |
| test(function mul() { |
| assertEquals(1, 1 * 1); |
| assertEquals(2.25, 1.5 * 1.5); |
| assertSame(Infinity, Infinity * Infinity); |
| assertSame(-Infinity, Infinity * (-Infinity)); |
| assertSame(Infinity, Infinity * 3); |
| assertSame(-Infinity, Infinity * (-3)); |
| assertSame(NaN, NaN * 3); |
| assertSame(-Infinity, 1 / (-0.0 * 0.0)); |
| assertSame(Infinity, 1 / (0.0 * 0.0)); |
| }); |
| |
| test(function div() { |
| assertEquals(1, 1 / 1); |
| assertEquals(1.5, 2.25 / 1.5); |
| assertSame(NaN, Infinity / Infinity); |
| assertSame(Infinity, Infinity / 3); |
| assertSame(-Infinity, Infinity / (-3)); |
| assertSame(NaN, NaN / 3); |
| assertSame(-Infinity, 1 / (-0.0)); |
| assertSame(Infinity, Infinity / 0.0); |
| }); |
| |
| test(function mathMin() { |
| assertEquals(1, Math.min(1, 10)); |
| assertEquals(1.5, Math.min(1.5, 2.5)); |
| assertEquals(0, Math.min(Infinity, 0)); |
| assertSame(Infinity, Math.min(Infinity, Infinity)); |
| assertSame(-Infinity, Math.min(Infinity, -Infinity)); |
| assertSame(NaN, Math.min(NaN, 1)); |
| assertSame(Infinity, 1 / Math.min(0.0, 0.0)); |
| assertSame(-Infinity, 1 / Math.min(-0.0, -0.0)); |
| assertSame(-Infinity, 1 / Math.min(0.0, -0.0)); |
| }); |
| |
| test(function mathMax() { |
| assertEquals(10, Math.max(1, 10)); |
| assertEquals(2.5, Math.max(1.5, 2.5)); |
| assertEquals(Infinity, Math.max(Infinity, 0)); |
| assertSame(-Infinity, Math.max(-Infinity, -Infinity)); |
| assertSame(Infinity, Math.max(Infinity, -Infinity)); |
| assertSame(NaN, Math.max(NaN, 1)); |
| assertSame(Infinity, 1 / Math.max(0.0, 0.0)); |
| assertSame(-Infinity, 1 / Math.max(-0.0, -0.0)); |
| assertSame(Infinity, 1 / Math.max(0.0, -0.0)); |
| }); |
| |
| test(function mathExp() { |
| assertEquals(1.0, Math.exp(0.0)); |
| assertTrue(2.7 < Math.exp(1) && Math.exp(1) < 2.8); |
| assertSame(Infinity, Math.exp(Infinity)); |
| assertEquals("0", String(Math.exp(-Infinity))); |
| assertSame(NaN, Math.exp(NaN)); |
| }); |
| |
| test(function mathLog() { |
| assertEquals(0.0, Math.log(1.0)); |
| assertTrue(1 < Math.log(3) && Math.log(3) < 1.5); |
| assertSame(Infinity, Math.log(Infinity)); |
| assertSame(NaN, Math.log(-Infinity)); |
| assertSame(NaN, Math.exp(NaN)); |
| }); |
| |
| test(function mathSqrt() { |
| assertEquals(1.0, Math.sqrt(1.0)); |
| assertSame(NaN, Math.sqrt(-1.0)); |
| assertSame(Infinity, Math.sqrt(Infinity)); |
| assertSame(NaN, Math.sqrt(-Infinity)); |
| assertSame(NaN, Math.sqrt(NaN)); |
| }); |
| |
| test(function mathPowHalf() { |
| assertEquals(1.0, Math.pow(1.0, 0.5)); |
| assertSame(NaN, Math.sqrt(-1.0)); |
| assertSame(Infinity, Math.pow(Infinity, 0.5)); |
| assertSame(NaN, Math.sqrt(-Infinity, 0.5)); |
| assertEquals(0, Math.pow(Infinity, -0.5)); |
| assertSame(NaN, Math.sqrt(-Infinity, -0.5)); |
| assertSame(NaN, Math.sqrt(NaN, 0.5)); |
| }); |
| |
| test(function mathAbs() { |
| assertEquals(1.5, Math.abs(1.5)); |
| assertEquals(1.5, Math.abs(-1.5)); |
| assertSame(Infinity, Math.abs(Infinity)); |
| assertSame(Infinity, Math.abs(-Infinity)); |
| assertSame(NaN, Math.abs(NaN)); |
| }); |
| |
| test(function mathRound() { |
| assertEquals(2, Math.round(1.5)); |
| assertEquals(-1, Math.round(-1.5)); |
| assertSame(Infinity, Math.round(Infinity)); |
| assertSame(-Infinity, Math.round(-Infinity)); |
| assertSame(Infinity, 1 / Math.round(0.0)); |
| assertSame(-Infinity, 1 / Math.round(-0.0)); |
| assertSame(NaN, Math.round(NaN)); |
| assertEquals(Math.pow(2, 52) + 1, Math.round(Math.pow(2, 52) + 1)); |
| }); |
| |
| test(function mathFround() { |
| assertTrue(isNaN(Math.fround(NaN))); |
| assertSame(Infinity, 1 / Math.fround(0)); |
| assertSame(-Infinity, 1 / Math.fround(-0)); |
| assertSame(Infinity, Math.fround(Infinity)); |
| assertSame(-Infinity, Math.fround(-Infinity)); |
| assertSame(Infinity, Math.fround(1E200)); |
| assertSame(-Infinity, Math.fround(-1E200)); |
| assertEquals(3.1415927410125732, Math.fround(Math.PI)); |
| }); |
| |
| test(function mathFloor() { |
| assertEquals(1, Math.floor(1.5)); |
| assertEquals(-2, Math.floor(-1.5)); |
| assertSame(Infinity, Math.floor(Infinity)); |
| assertSame(-Infinity, Math.floor(-Infinity)); |
| assertSame(Infinity, 1 / Math.floor(0.0)); |
| assertSame(-Infinity, 1 / Math.floor(-0.0)); |
| assertSame(NaN, Math.floor(NaN)); |
| assertEquals(Math.pow(2, 52) + 1, Math.floor(Math.pow(2, 52) + 1)); |
| }); |
| |
| test(function mathPow() { |
| assertEquals(2.25, Math.pow(1.5, 2)); |
| assertTrue(1.8 < Math.pow(1.5, 1.5) && Math.pow(1.5, 1.5) < 1.9); |
| assertSame(Infinity, Math.pow(Infinity, 0.5)); |
| assertSame(Infinity, Math.pow(-Infinity, 0.5)); |
| assertEquals(0, Math.pow(Infinity, -0.5)); |
| assertEquals(0, Math.pow(Infinity, -0.5)); |
| assertSame(Infinity, Math.pow(Infinity, Infinity)); |
| assertEquals(0, Math.pow(Infinity, -Infinity)); |
| assertSame(NaN, Math.pow(Infinity, NaN)); |
| assertSame(NaN, Math.pow(NaN, 2)); |
| }); |
| |
| test(function stringAdd() { |
| assertEquals("", "" + ""); |
| assertEquals("folded constant", "folded " + "constant"); |
| assertEquals("not folded constant1", "not folded constant" + 1); |
| }); |
| |
| test(function stringLength() { |
| assertEquals(6, "abcdef".length); |
| assertEquals(0, "".length); |
| assertEquals(-5, { length: -5 }.length); |
| }); |
| |
| test(function stringCharAt() { |
| assertEquals("c", "abc".charAt(2)); |
| assertEquals("", "abc".charAt(-1)); |
| assertEquals("", "abc".charAt(4)); |
| assertEquals("b", "abc".charAt(1.1)); |
| assertEquals("", "abc".charAt(4.1)); |
| assertEquals("", "abc".charAt(Infinity)); |
| assertEquals("", "abc".charAt(-Infinity)); |
| assertEquals("a", "abc".charAt(-0)); |
| assertEquals("a", "abc".charAt(+0)); |
| assertEquals("", "".charAt()); |
| assertEquals("", "abc".charAt(1 + 4294967295)); |
| }, 10); |
| |
| test(function stringCharCodeAt() { |
| assertSame(99, "abc".charCodeAt(2)); |
| assertSame(NaN, "abc".charCodeAt(-1)); |
| assertSame(NaN, "abc".charCodeAt(4)); |
| assertSame(98, "abc".charCodeAt(1.1)); |
| assertSame(NaN, "abc".charCodeAt(4.1)); |
| assertSame(NaN, "abc".charCodeAt(Infinity)); |
| assertSame(NaN, "abc".charCodeAt(-Infinity)); |
| assertSame(97, "abc".charCodeAt(-0)); |
| assertSame(97, "abc".charCodeAt(+0)); |
| assertSame(NaN, "".charCodeAt()); |
| assertSame(NaN, "abc".charCodeAt(1 + 4294967295)); |
| }, 10); |
| |
| test(function stringCodePointAt() { |
| assertSame(65533, "äϠ�𝌆".codePointAt(2)); |
| assertSame(119558, "äϠ�𝌆".codePointAt(3)); |
| assertSame(undefined, "äϠ�".codePointAt(-1)); |
| assertSame(undefined, "äϠ�".codePointAt(4)); |
| assertSame(992, "äϠ�".codePointAt(1.1)); |
| assertSame(undefined, "äϠ�".codePointAt(4.1)); |
| assertSame(undefined, "äϠ�".codePointAt(Infinity)); |
| assertSame(undefined, "äϠ�".codePointAt(-Infinity)); |
| assertSame(228, "äϠ�".codePointAt(-0)); |
| assertSame(97, "aϠ�".codePointAt(+0)); |
| assertSame(undefined, "".codePointAt()); |
| assertSame(undefined, "äϠ�".codePointAt(1 + 4294967295)); |
| }, 10); |
| |
| test(function stringFromCodePoint() { |
| assertEquals(String.fromCodePoint(), ""); |
| assertEquals(String.fromCodePoint(-0), "\0"); |
| assertEquals(String.fromCodePoint(0), "\0"); |
| assertEquals(String.fromCodePoint(0x1D306), "\uD834\uDF06"); |
| assertEquals( |
| String.fromCodePoint(0x1D306, 0x61, 0x1D307), |
| "\uD834\uDF06a\uD834\uDF07"); |
| assertEquals(String.fromCodePoint(0x61, 0x62, 0x1D307), "ab\uD834\uDF07"); |
| assertEquals(String.fromCodePoint(false), "\0"); |
| assertEquals(String.fromCodePoint(null), "\0"); |
| }, 5); |
| |
| test(function stringFromCharCode() { |
| assertEquals("!", String.fromCharCode(0x10FF01)); |
| }, 2); |
| |
| test(function int32Mod() { |
| assertEquals(-0, -2147483648 % (-1)); |
| }); |
| |
| test(function int32Div() { |
| assertEquals(2147483648, -2147483648 / (-1)); |
| }); |