summaryrefslogtreecommitdiffstats
path: root/Source/JavaScriptCore/tests/mozilla/ecma/LexicalConventions/7.7.3.js
diff options
context:
space:
mode:
Diffstat (limited to 'Source/JavaScriptCore/tests/mozilla/ecma/LexicalConventions/7.7.3.js')
-rw-r--r--Source/JavaScriptCore/tests/mozilla/ecma/LexicalConventions/7.7.3.js337
1 files changed, 337 insertions, 0 deletions
diff --git a/Source/JavaScriptCore/tests/mozilla/ecma/LexicalConventions/7.7.3.js b/Source/JavaScriptCore/tests/mozilla/ecma/LexicalConventions/7.7.3.js
new file mode 100644
index 0000000..7d47a40
--- /dev/null
+++ b/Source/JavaScriptCore/tests/mozilla/ecma/LexicalConventions/7.7.3.js
@@ -0,0 +1,337 @@
+/* The contents of this file are subject to the Netscape Public
+ * License Version 1.1 (the "License"); you may not use this file
+ * except in compliance with the License. You may obtain a copy of
+ * the License at http://www.mozilla.org/NPL/
+ *
+ * Software distributed under the License is distributed on an "AS
+ * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
+ * implied. See the License for the specific language governing
+ * rights and limitations under the License.
+ *
+ * The Original Code is Mozilla Communicator client code, released March
+ * 31, 1998.
+ *
+ * The Initial Developer of the Original Code is Netscape Communications
+ * Corporation. Portions created by Netscape are
+ * Copyright (C) 1998 Netscape Communications Corporation. All
+ * Rights Reserved.
+ *
+ * Contributor(s):
+ *
+ */
+/**
+ File Name: 7.7.3.js
+ ECMA Section: 7.7.3 Numeric Literals
+
+ Description: A numeric literal stands for a value of the Number type
+ This value is determined in two steps: first a
+ mathematical value (MV) is derived from the literal;
+ second, this mathematical value is rounded, ideally
+ using IEEE 754 round-to-nearest mode, to a reprentable
+ value of of the number type.
+
+ Author: christine@netscape.com
+ Date: 16 september 1997
+*/
+ var SECTION = "7.7.3";
+ var VERSION = "ECMA_1";
+ startTest();
+ var TITLE = "Numeric Literals";
+
+ writeHeaderToLog( SECTION + " "+ TITLE);
+
+ var testcases = getTestCases();
+ test();
+
+
+function getTestCases() {
+ var array = new Array();
+ var item = 0;
+
+ array[item++] = new TestCase( SECTION, "0", 0, 0 );
+ array[item++] = new TestCase( SECTION, "1", 1, 1 );
+ array[item++] = new TestCase( SECTION, "2", 2, 2 );
+ array[item++] = new TestCase( SECTION, "3", 3, 3 );
+ array[item++] = new TestCase( SECTION, "4", 4, 4 );
+ array[item++] = new TestCase( SECTION, "5", 5, 5 );
+ array[item++] = new TestCase( SECTION, "6", 6, 6 );
+ array[item++] = new TestCase( SECTION, "7", 7, 7 );
+ array[item++] = new TestCase( SECTION, "8", 8, 8 );
+ array[item++] = new TestCase( SECTION, "9", 9, 9 );
+
+ array[item++] = new TestCase( SECTION, "0.", 0, 0. );
+ array[item++] = new TestCase( SECTION, "1.", 1, 1. );
+ array[item++] = new TestCase( SECTION, "2.", 2, 2. );
+ array[item++] = new TestCase( SECTION, "3.", 3, 3. );
+ array[item++] = new TestCase( SECTION, "4.", 4, 4. );
+
+ array[item++] = new TestCase( SECTION, "0.e0", 0, 0.e0 );
+ array[item++] = new TestCase( SECTION, "1.e1", 10, 1.e1 );
+ array[item++] = new TestCase( SECTION, "2.e2", 200, 2.e2 );
+ array[item++] = new TestCase( SECTION, "3.e3", 3000, 3.e3 );
+ array[item++] = new TestCase( SECTION, "4.e4", 40000, 4.e4 );
+
+ array[item++] = new TestCase( SECTION, "0.1e0", .1, 0.1e0 );
+ array[item++] = new TestCase( SECTION, "1.1e1", 11, 1.1e1 );
+ array[item++] = new TestCase( SECTION, "2.2e2", 220, 2.2e2 );
+ array[item++] = new TestCase( SECTION, "3.3e3", 3300, 3.3e3 );
+ array[item++] = new TestCase( SECTION, "4.4e4", 44000, 4.4e4 );
+
+ array[item++] = new TestCase( SECTION, ".1e0", .1, .1e0 );
+ array[item++] = new TestCase( SECTION, ".1e1", 1, .1e1 );
+ array[item++] = new TestCase( SECTION, ".2e2", 20, .2e2 );
+ array[item++] = new TestCase( SECTION, ".3e3", 300, .3e3 );
+ array[item++] = new TestCase( SECTION, ".4e4", 4000, .4e4 );
+
+ array[item++] = new TestCase( SECTION, "0e0", 0, 0e0 );
+ array[item++] = new TestCase( SECTION, "1e1", 10, 1e1 );
+ array[item++] = new TestCase( SECTION, "2e2", 200, 2e2 );
+ array[item++] = new TestCase( SECTION, "3e3", 3000, 3e3 );
+ array[item++] = new TestCase( SECTION, "4e4", 40000, 4e4 );
+
+ array[item++] = new TestCase( SECTION, "0e0", 0, 0e0 );
+ array[item++] = new TestCase( SECTION, "1e1", 10, 1e1 );
+ array[item++] = new TestCase( SECTION, "2e2", 200, 2e2 );
+ array[item++] = new TestCase( SECTION, "3e3", 3000, 3e3 );
+ array[item++] = new TestCase( SECTION, "4e4", 40000, 4e4 );
+
+ array[item++] = new TestCase( SECTION, "0E0", 0, 0E0 );
+ array[item++] = new TestCase( SECTION, "1E1", 10, 1E1 );
+ array[item++] = new TestCase( SECTION, "2E2", 200, 2E2 );
+ array[item++] = new TestCase( SECTION, "3E3", 3000, 3E3 );
+ array[item++] = new TestCase( SECTION, "4E4", 40000, 4E4 );
+
+ array[item++] = new TestCase( SECTION, "1.e-1", 0.1, 1.e-1 );
+ array[item++] = new TestCase( SECTION, "2.e-2", 0.02, 2.e-2 );
+ array[item++] = new TestCase( SECTION, "3.e-3", 0.003, 3.e-3 );
+ array[item++] = new TestCase( SECTION, "4.e-4", 0.0004, 4.e-4 );
+
+ array[item++] = new TestCase( SECTION, "0.1e-0", .1, 0.1e-0 );
+ array[item++] = new TestCase( SECTION, "1.1e-1", 0.11, 1.1e-1 );
+ array[item++] = new TestCase( SECTION, "2.2e-2", .022, 2.2e-2 );
+ array[item++] = new TestCase( SECTION, "3.3e-3", .0033, 3.3e-3 );
+ array[item++] = new TestCase( SECTION, "4.4e-4", .00044, 4.4e-4 );
+
+ array[item++] = new TestCase( SECTION, ".1e-0", .1, .1e-0 );
+ array[item++] = new TestCase( SECTION, ".1e-1", .01, .1e-1 );
+ array[item++] = new TestCase( SECTION, ".2e-2", .002, .2e-2 );
+ array[item++] = new TestCase( SECTION, ".3e-3", .0003, .3e-3 );
+ array[item++] = new TestCase( SECTION, ".4e-4", .00004, .4e-4 );
+
+ array[item++] = new TestCase( SECTION, "1.e+1", 10, 1.e+1 );
+ array[item++] = new TestCase( SECTION, "2.e+2", 200, 2.e+2 );
+ array[item++] = new TestCase( SECTION, "3.e+3", 3000, 3.e+3 );
+ array[item++] = new TestCase( SECTION, "4.e+4", 40000, 4.e+4 );
+
+ array[item++] = new TestCase( SECTION, "0.1e+0", .1, 0.1e+0 );
+ array[item++] = new TestCase( SECTION, "1.1e+1", 11, 1.1e+1 );
+ array[item++] = new TestCase( SECTION, "2.2e+2", 220, 2.2e+2 );
+ array[item++] = new TestCase( SECTION, "3.3e+3", 3300, 3.3e+3 );
+ array[item++] = new TestCase( SECTION, "4.4e+4", 44000, 4.4e+4 );
+
+ array[item++] = new TestCase( SECTION, ".1e+0", .1, .1e+0 );
+ array[item++] = new TestCase( SECTION, ".1e+1", 1, .1e+1 );
+ array[item++] = new TestCase( SECTION, ".2e+2", 20, .2e+2 );
+ array[item++] = new TestCase( SECTION, ".3e+3", 300, .3e+3 );
+ array[item++] = new TestCase( SECTION, ".4e+4", 4000, .4e+4 );
+
+ array[item++] = new TestCase( SECTION, "0x0", 0, 0x0 );
+ array[item++] = new TestCase( SECTION, "0x1", 1, 0x1 );
+ array[item++] = new TestCase( SECTION, "0x2", 2, 0x2 );
+ array[item++] = new TestCase( SECTION, "0x3", 3, 0x3 );
+ array[item++] = new TestCase( SECTION, "0x4", 4, 0x4 );
+ array[item++] = new TestCase( SECTION, "0x5", 5, 0x5 );
+ array[item++] = new TestCase( SECTION, "0x6", 6, 0x6 );
+ array[item++] = new TestCase( SECTION, "0x7", 7, 0x7 );
+ array[item++] = new TestCase( SECTION, "0x8", 8, 0x8 );
+ array[item++] = new TestCase( SECTION, "0x9", 9, 0x9 );
+ array[item++] = new TestCase( SECTION, "0xa", 10, 0xa );
+ array[item++] = new TestCase( SECTION, "0xb", 11, 0xb );
+ array[item++] = new TestCase( SECTION, "0xc", 12, 0xc );
+ array[item++] = new TestCase( SECTION, "0xd", 13, 0xd );
+ array[item++] = new TestCase( SECTION, "0xe", 14, 0xe );
+ array[item++] = new TestCase( SECTION, "0xf", 15, 0xf );
+
+ array[item++] = new TestCase( SECTION, "0X0", 0, 0X0 );
+ array[item++] = new TestCase( SECTION, "0X1", 1, 0X1 );
+ array[item++] = new TestCase( SECTION, "0X2", 2, 0X2 );
+ array[item++] = new TestCase( SECTION, "0X3", 3, 0X3 );
+ array[item++] = new TestCase( SECTION, "0X4", 4, 0X4 );
+ array[item++] = new TestCase( SECTION, "0X5", 5, 0X5 );
+ array[item++] = new TestCase( SECTION, "0X6", 6, 0X6 );
+ array[item++] = new TestCase( SECTION, "0X7", 7, 0X7 );
+ array[item++] = new TestCase( SECTION, "0X8", 8, 0X8 );
+ array[item++] = new TestCase( SECTION, "0X9", 9, 0X9 );
+ array[item++] = new TestCase( SECTION, "0Xa", 10, 0Xa );
+ array[item++] = new TestCase( SECTION, "0Xb", 11, 0Xb );
+ array[item++] = new TestCase( SECTION, "0Xc", 12, 0Xc );
+ array[item++] = new TestCase( SECTION, "0Xd", 13, 0Xd );
+ array[item++] = new TestCase( SECTION, "0Xe", 14, 0Xe );
+ array[item++] = new TestCase( SECTION, "0Xf", 15, 0Xf );
+
+ array[item++] = new TestCase( SECTION, "0x0", 0, 0x0 );
+ array[item++] = new TestCase( SECTION, "0x1", 1, 0x1 );
+ array[item++] = new TestCase( SECTION, "0x2", 2, 0x2 );
+ array[item++] = new TestCase( SECTION, "0x3", 3, 0x3 );
+ array[item++] = new TestCase( SECTION, "0x4", 4, 0x4 );
+ array[item++] = new TestCase( SECTION, "0x5", 5, 0x5 );
+ array[item++] = new TestCase( SECTION, "0x6", 6, 0x6 );
+ array[item++] = new TestCase( SECTION, "0x7", 7, 0x7 );
+ array[item++] = new TestCase( SECTION, "0x8", 8, 0x8 );
+ array[item++] = new TestCase( SECTION, "0x9", 9, 0x9 );
+ array[item++] = new TestCase( SECTION, "0xA", 10, 0xA );
+ array[item++] = new TestCase( SECTION, "0xB", 11, 0xB );
+ array[item++] = new TestCase( SECTION, "0xC", 12, 0xC );
+ array[item++] = new TestCase( SECTION, "0xD", 13, 0xD );
+ array[item++] = new TestCase( SECTION, "0xE", 14, 0xE );
+ array[item++] = new TestCase( SECTION, "0xF", 15, 0xF );
+
+ array[item++] = new TestCase( SECTION, "0X0", 0, 0X0 );
+ array[item++] = new TestCase( SECTION, "0X1", 1, 0X1 );
+ array[item++] = new TestCase( SECTION, "0X2", 2, 0X2 );
+ array[item++] = new TestCase( SECTION, "0X3", 3, 0X3 );
+ array[item++] = new TestCase( SECTION, "0X4", 4, 0X4 );
+ array[item++] = new TestCase( SECTION, "0X5", 5, 0X5 );
+ array[item++] = new TestCase( SECTION, "0X6", 6, 0X6 );
+ array[item++] = new TestCase( SECTION, "0X7", 7, 0X7 );
+ array[item++] = new TestCase( SECTION, "0X8", 8, 0X8 );
+ array[item++] = new TestCase( SECTION, "0X9", 9, 0X9 );
+ array[item++] = new TestCase( SECTION, "0XA", 10, 0XA );
+ array[item++] = new TestCase( SECTION, "0XB", 11, 0XB );
+ array[item++] = new TestCase( SECTION, "0XC", 12, 0XC );
+ array[item++] = new TestCase( SECTION, "0XD", 13, 0XD );
+ array[item++] = new TestCase( SECTION, "0XE", 14, 0XE );
+ array[item++] = new TestCase( SECTION, "0XF", 15, 0XF );
+
+
+ array[item++] = new TestCase( SECTION, "00", 0, 00 );
+ array[item++] = new TestCase( SECTION, "01", 1, 01 );
+ array[item++] = new TestCase( SECTION, "02", 2, 02 );
+ array[item++] = new TestCase( SECTION, "03", 3, 03 );
+ array[item++] = new TestCase( SECTION, "04", 4, 04 );
+ array[item++] = new TestCase( SECTION, "05", 5, 05 );
+ array[item++] = new TestCase( SECTION, "06", 6, 06 );
+ array[item++] = new TestCase( SECTION, "07", 7, 07 );
+
+ array[item++] = new TestCase( SECTION, "000", 0, 000 );
+ array[item++] = new TestCase( SECTION, "011", 9, 011 );
+ array[item++] = new TestCase( SECTION, "022", 18, 022 );
+ array[item++] = new TestCase( SECTION, "033", 27, 033 );
+ array[item++] = new TestCase( SECTION, "044", 36, 044 );
+ array[item++] = new TestCase( SECTION, "055", 45, 055 );
+ array[item++] = new TestCase( SECTION, "066", 54, 066 );
+ array[item++] = new TestCase( SECTION, "077", 63, 077 );
+
+ array[item++] = new TestCase( SECTION, "0.00000000001", 0.00000000001, 0.00000000001 );
+ array[item++] = new TestCase( SECTION, "0.00000000001e-2", 0.0000000000001, 0.00000000001e-2 );
+
+
+ array[item++] = new TestCase( SECTION,
+ "123456789012345671.9999",
+ "123456789012345660",
+ 123456789012345671.9999 +"");
+ array[item++] = new TestCase( SECTION,
+ "123456789012345672",
+ "123456789012345660",
+ 123456789012345672 +"");
+
+ array[item++] = new TestCase( SECTION,
+ "123456789012345672.000000000000000000000000000",
+ "123456789012345660",
+ 123456789012345672.000000000000000000000000000 +"");
+
+ array[item++] = new TestCase( SECTION,
+ "123456789012345672.01",
+ "123456789012345680",
+ 123456789012345672.01 +"");
+
+ array[item++] = new TestCase( SECTION,
+ "123456789012345672.000000000000000000000000001+'' == 123456789012345680 || 123456789012345660",
+ true,
+ ( 123456789012345672.00000000000000000000000000 +"" == 1234567890 * 100000000 + 12345680 )
+ ||
+ ( 123456789012345672.00000000000000000000000000 +"" == 1234567890 * 100000000 + 12345660) );
+
+ array[item++] = new TestCase( SECTION,
+ "123456789012345673",
+ "123456789012345680",
+ 123456789012345673 +"" );
+
+ array[item++] = new TestCase( SECTION,
+ "-123456789012345671.9999",
+ "-123456789012345660",
+ -123456789012345671.9999 +"" );
+
+ array[item++] = new TestCase( SECTION,
+ "-123456789012345672",
+ "-123456789012345660",
+ -123456789012345672+"");
+
+ array[item++] = new TestCase( SECTION,
+ "-123456789012345672.000000000000000000000000000",
+ "-123456789012345660",
+ -123456789012345672.000000000000000000000000000 +"");
+
+ array[item++] = new TestCase( SECTION,
+ "-123456789012345672.01",
+ "-123456789012345680",
+ -123456789012345672.01 +"" );
+
+ array[item++] = new TestCase( SECTION,
+ "-123456789012345672.000000000000000000000000001 == -123456789012345680 or -123456789012345660",
+ true,
+ (-123456789012345672.000000000000000000000000001 +"" == -1234567890 * 100000000 -12345680)
+ ||
+ (-123456789012345672.000000000000000000000000001 +"" == -1234567890 * 100000000 -12345660));
+
+ array[item++] = new TestCase( SECTION,
+ -123456789012345673,
+ "-123456789012345680",
+ -123456789012345673 +"");
+
+ array[item++] = new TestCase( SECTION,
+ "12345678901234567890",
+ "12345678901234567000",
+ 12345678901234567890 +"" );
+
+
+/*
+ array[item++] = new TestCase( SECTION, "12345678901234567", "12345678901234567", 12345678901234567+"" );
+ array[item++] = new TestCase( SECTION, "123456789012345678", "123456789012345678", 123456789012345678+"" );
+ array[item++] = new TestCase( SECTION, "1234567890123456789", "1234567890123456789", 1234567890123456789+"" );
+ array[item++] = new TestCase( SECTION, "12345678901234567890", "12345678901234567890", 12345678901234567890+"" );
+ array[item++] = new TestCase( SECTION, "123456789012345678900", "123456789012345678900", 123456789012345678900+"" );
+ array[item++] = new TestCase( SECTION, "1234567890123456789000", "1234567890123456789000", 1234567890123456789000+"" );
+*/
+ array[item++] = new TestCase( SECTION, "0x1", 1, 0x1 );
+ array[item++] = new TestCase( SECTION, "0x10", 16, 0x10 );
+ array[item++] = new TestCase( SECTION, "0x100", 256, 0x100 );
+ array[item++] = new TestCase( SECTION, "0x1000", 4096, 0x1000 );
+ array[item++] = new TestCase( SECTION, "0x10000", 65536, 0x10000 );
+ array[item++] = new TestCase( SECTION, "0x100000", 1048576, 0x100000 );
+ array[item++] = new TestCase( SECTION, "0x1000000", 16777216, 0x1000000 );
+ array[item++] = new TestCase( SECTION, "0x10000000", 268435456, 0x10000000 );
+/*
+ array[item++] = new TestCase( SECTION, "0x100000000", 4294967296, 0x100000000 );
+ array[item++] = new TestCase( SECTION, "0x1000000000", 68719476736, 0x1000000000 );
+ array[item++] = new TestCase( SECTION, "0x10000000000", 1099511627776, 0x10000000000 );
+*/
+ return ( array );
+}
+
+function test() {
+ for ( tc=0; tc < testcases.length; tc++ ) {
+ testcases[tc].actual = testcases[tc].actual;
+
+ testcases[tc].passed = writeTestCaseResult(
+ testcases[tc].expect,
+ testcases[tc].actual,
+ testcases[tc].description +" = "+ testcases[tc].actual );
+
+ testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
+
+ }
+
+ stopTest();
+ return ( testcases );
+}