d1ea04ea41a7453591485205530a67705cf49c52
[WebKit-https.git] / JSTests / mozilla / ecma / LexicalConventions / 7.7.3.js
1 //@ skip
2 /* The contents of this file are subject to the Netscape Public
3  * License Version 1.1 (the "License"); you may not use this file
4  * except in compliance with the License. You may obtain a copy of
5  * the License at http://www.mozilla.org/NPL/
6  *
7  * Software distributed under the License is distributed on an "AS
8  * IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
9  * implied. See the License for the specific language governing
10  * rights and limitations under the License.
11  *
12  * The Original Code is Mozilla Communicator client code, released March
13  * 31, 1998.
14  *
15  * The Initial Developer of the Original Code is Netscape Communications
16  * Corporation. Portions created by Netscape are
17  * Copyright (C) 1998 Netscape Communications Corporation. All
18  * Rights Reserved.
19  *
20  * Contributor(s): 
21  * 
22  */
23 /**
24     File Name:          7.7.3.js
25     ECMA Section:       7.7.3 Numeric Literals
26
27     Description:        A numeric literal stands for a value of the Number type
28                         This value is determined in two steps:  first a
29                         mathematical value (MV) is derived from the literal;
30                         second, this mathematical value is rounded, ideally
31                         using IEEE 754 round-to-nearest mode, to a reprentable
32                         value of of the number type.
33
34     Author:             christine@netscape.com
35     Date:               16 september 1997
36 */
37     var SECTION = "7.7.3";
38     var VERSION = "ECMA_1";
39     startTest();
40     var TITLE   = "Numeric Literals";
41
42     writeHeaderToLog( SECTION + " "+ TITLE);
43
44     var testcases = getTestCases();
45     test();
46
47
48 function getTestCases() {
49     var array = new Array();
50     var item = 0;
51
52     array[item++] = new TestCase( SECTION, "0",     0,      0 );
53     array[item++] = new TestCase( SECTION, "1",     1,      1 );
54     array[item++] = new TestCase( SECTION, "2",     2,      2 );
55     array[item++] = new TestCase( SECTION, "3",     3,      3 );
56     array[item++] = new TestCase( SECTION, "4",     4,      4 );
57     array[item++] = new TestCase( SECTION, "5",     5,      5 );
58     array[item++] = new TestCase( SECTION, "6",     6,      6 );
59     array[item++] = new TestCase( SECTION, "7",     7,      7 );
60     array[item++] = new TestCase( SECTION, "8",     8,      8 );
61     array[item++] = new TestCase( SECTION, "9",     9,      9 );
62
63     array[item++] = new TestCase( SECTION, "0.",     0,      0. );
64     array[item++] = new TestCase( SECTION, "1.",     1,      1. );
65     array[item++] = new TestCase( SECTION, "2.",     2,      2. );
66     array[item++] = new TestCase( SECTION, "3.",     3,      3. );
67     array[item++] = new TestCase( SECTION, "4.",     4,      4. );
68
69     array[item++] = new TestCase( SECTION, "0.e0",  0,      0.e0 );
70     array[item++] = new TestCase( SECTION, "1.e1",  10,     1.e1 );
71     array[item++] = new TestCase( SECTION, "2.e2",  200,    2.e2 );
72     array[item++] = new TestCase( SECTION, "3.e3",  3000,   3.e3 );
73     array[item++] = new TestCase( SECTION, "4.e4",  40000,  4.e4 );
74
75     array[item++] = new TestCase( SECTION, "0.1e0",  .1,    0.1e0 );
76     array[item++] = new TestCase( SECTION, "1.1e1",  11,    1.1e1 );
77     array[item++] = new TestCase( SECTION, "2.2e2",  220,   2.2e2 );
78     array[item++] = new TestCase( SECTION, "3.3e3",  3300,  3.3e3 );
79     array[item++] = new TestCase( SECTION, "4.4e4",  44000, 4.4e4 );
80
81     array[item++] = new TestCase( SECTION, ".1e0",  .1,   .1e0 );
82     array[item++] = new TestCase( SECTION, ".1e1",  1,    .1e1 );
83     array[item++] = new TestCase( SECTION, ".2e2",  20,   .2e2 );
84     array[item++] = new TestCase( SECTION, ".3e3",  300,  .3e3 );
85     array[item++] = new TestCase( SECTION, ".4e4",  4000, .4e4 );
86
87     array[item++] = new TestCase( SECTION, "0e0",  0,     0e0 );
88     array[item++] = new TestCase( SECTION, "1e1",  10,    1e1 );
89     array[item++] = new TestCase( SECTION, "2e2",  200,   2e2 );
90     array[item++] = new TestCase( SECTION, "3e3",  3000,  3e3 );
91     array[item++] = new TestCase( SECTION, "4e4",  40000, 4e4 );
92
93     array[item++] = new TestCase( SECTION, "0e0",  0,     0e0 );
94     array[item++] = new TestCase( SECTION, "1e1",  10,    1e1 );
95     array[item++] = new TestCase( SECTION, "2e2",  200,   2e2 );
96     array[item++] = new TestCase( SECTION, "3e3",  3000,  3e3 );
97     array[item++] = new TestCase( SECTION, "4e4",  40000, 4e4 );
98
99     array[item++] = new TestCase( SECTION, "0E0",  0,     0E0 );
100     array[item++] = new TestCase( SECTION, "1E1",  10,    1E1 );
101     array[item++] = new TestCase( SECTION, "2E2",  200,   2E2 );
102     array[item++] = new TestCase( SECTION, "3E3",  3000,  3E3 );
103     array[item++] = new TestCase( SECTION, "4E4",  40000, 4E4 );
104
105     array[item++] = new TestCase( SECTION, "1.e-1",  0.1,     1.e-1 );
106     array[item++] = new TestCase( SECTION, "2.e-2",  0.02,    2.e-2 );
107     array[item++] = new TestCase( SECTION, "3.e-3",  0.003,   3.e-3 );
108     array[item++] = new TestCase( SECTION, "4.e-4",  0.0004,  4.e-4 );
109
110     array[item++] = new TestCase( SECTION, "0.1e-0",  .1,     0.1e-0 );
111     array[item++] = new TestCase( SECTION, "1.1e-1",  0.11,   1.1e-1 );
112     array[item++] = new TestCase( SECTION, "2.2e-2",  .022,   2.2e-2 );
113     array[item++] = new TestCase( SECTION, "3.3e-3",  .0033,  3.3e-3 );
114     array[item++] = new TestCase( SECTION, "4.4e-4",  .00044, 4.4e-4 );
115
116     array[item++] = new TestCase( SECTION, ".1e-0",  .1,    .1e-0 );
117     array[item++] = new TestCase( SECTION, ".1e-1",  .01,    .1e-1 );
118     array[item++] = new TestCase( SECTION, ".2e-2",  .002,   .2e-2 );
119     array[item++] = new TestCase( SECTION, ".3e-3",  .0003,  .3e-3 );
120     array[item++] = new TestCase( SECTION, ".4e-4",  .00004, .4e-4 );
121
122     array[item++] = new TestCase( SECTION, "1.e+1",  10,     1.e+1 );
123     array[item++] = new TestCase( SECTION, "2.e+2",  200,    2.e+2 );
124     array[item++] = new TestCase( SECTION, "3.e+3",  3000,   3.e+3 );
125     array[item++] = new TestCase( SECTION, "4.e+4",  40000,  4.e+4 );
126
127     array[item++] = new TestCase( SECTION, "0.1e+0",  .1,    0.1e+0 );
128     array[item++] = new TestCase( SECTION, "1.1e+1",  11,    1.1e+1 );
129     array[item++] = new TestCase( SECTION, "2.2e+2",  220,   2.2e+2 );
130     array[item++] = new TestCase( SECTION, "3.3e+3",  3300,  3.3e+3 );
131     array[item++] = new TestCase( SECTION, "4.4e+4",  44000, 4.4e+4 );
132
133     array[item++] = new TestCase( SECTION, ".1e+0",  .1,   .1e+0 );
134     array[item++] = new TestCase( SECTION, ".1e+1",  1,    .1e+1 );
135     array[item++] = new TestCase( SECTION, ".2e+2",  20,   .2e+2 );
136     array[item++] = new TestCase( SECTION, ".3e+3",  300,  .3e+3 );
137     array[item++] = new TestCase( SECTION, ".4e+4",  4000, .4e+4 );
138
139     array[item++] = new TestCase( SECTION, "0x0",  0,   0x0 );
140     array[item++] = new TestCase( SECTION, "0x1",  1,   0x1 );
141     array[item++] = new TestCase( SECTION, "0x2",  2,   0x2 );
142     array[item++] = new TestCase( SECTION, "0x3",  3,   0x3 );
143     array[item++] = new TestCase( SECTION, "0x4",  4,   0x4 );
144     array[item++] = new TestCase( SECTION, "0x5",  5,   0x5 );
145     array[item++] = new TestCase( SECTION, "0x6",  6,   0x6 );
146     array[item++] = new TestCase( SECTION, "0x7",  7,   0x7 );
147     array[item++] = new TestCase( SECTION, "0x8",  8,   0x8 );
148     array[item++] = new TestCase( SECTION, "0x9",  9,   0x9 );
149     array[item++] = new TestCase( SECTION, "0xa",  10,  0xa );
150     array[item++] = new TestCase( SECTION, "0xb",  11,  0xb );
151     array[item++] = new TestCase( SECTION, "0xc",  12,  0xc );
152     array[item++] = new TestCase( SECTION, "0xd",  13,  0xd );
153     array[item++] = new TestCase( SECTION, "0xe",  14,  0xe );
154     array[item++] = new TestCase( SECTION, "0xf",  15,  0xf );
155
156     array[item++] = new TestCase( SECTION, "0X0",  0,   0X0 );
157     array[item++] = new TestCase( SECTION, "0X1",  1,   0X1 );
158     array[item++] = new TestCase( SECTION, "0X2",  2,   0X2 );
159     array[item++] = new TestCase( SECTION, "0X3",  3,   0X3 );
160     array[item++] = new TestCase( SECTION, "0X4",  4,   0X4 );
161     array[item++] = new TestCase( SECTION, "0X5",  5,   0X5 );
162     array[item++] = new TestCase( SECTION, "0X6",  6,   0X6 );
163     array[item++] = new TestCase( SECTION, "0X7",  7,   0X7 );
164     array[item++] = new TestCase( SECTION, "0X8",  8,   0X8 );
165     array[item++] = new TestCase( SECTION, "0X9",  9,   0X9 );
166     array[item++] = new TestCase( SECTION, "0Xa",  10,  0Xa );
167     array[item++] = new TestCase( SECTION, "0Xb",  11,  0Xb );
168     array[item++] = new TestCase( SECTION, "0Xc",  12,  0Xc );
169     array[item++] = new TestCase( SECTION, "0Xd",  13,  0Xd );
170     array[item++] = new TestCase( SECTION, "0Xe",  14,  0Xe );
171     array[item++] = new TestCase( SECTION, "0Xf",  15,  0Xf );
172
173     array[item++] = new TestCase( SECTION, "0x0",  0,   0x0 );
174     array[item++] = new TestCase( SECTION, "0x1",  1,   0x1 );
175     array[item++] = new TestCase( SECTION, "0x2",  2,   0x2 );
176     array[item++] = new TestCase( SECTION, "0x3",  3,   0x3 );
177     array[item++] = new TestCase( SECTION, "0x4",  4,   0x4 );
178     array[item++] = new TestCase( SECTION, "0x5",  5,   0x5 );
179     array[item++] = new TestCase( SECTION, "0x6",  6,   0x6 );
180     array[item++] = new TestCase( SECTION, "0x7",  7,   0x7 );
181     array[item++] = new TestCase( SECTION, "0x8",  8,   0x8 );
182     array[item++] = new TestCase( SECTION, "0x9",  9,   0x9 );
183     array[item++] = new TestCase( SECTION, "0xA",  10,  0xA );
184     array[item++] = new TestCase( SECTION, "0xB",  11,  0xB );
185     array[item++] = new TestCase( SECTION, "0xC",  12,  0xC );
186     array[item++] = new TestCase( SECTION, "0xD",  13,  0xD );
187     array[item++] = new TestCase( SECTION, "0xE",  14,  0xE );
188     array[item++] = new TestCase( SECTION, "0xF",  15,  0xF );
189
190     array[item++] = new TestCase( SECTION, "0X0",  0,   0X0 );
191     array[item++] = new TestCase( SECTION, "0X1",  1,   0X1 );
192     array[item++] = new TestCase( SECTION, "0X2",  2,   0X2 );
193     array[item++] = new TestCase( SECTION, "0X3",  3,   0X3 );
194     array[item++] = new TestCase( SECTION, "0X4",  4,   0X4 );
195     array[item++] = new TestCase( SECTION, "0X5",  5,   0X5 );
196     array[item++] = new TestCase( SECTION, "0X6",  6,   0X6 );
197     array[item++] = new TestCase( SECTION, "0X7",  7,   0X7 );
198     array[item++] = new TestCase( SECTION, "0X8",  8,   0X8 );
199     array[item++] = new TestCase( SECTION, "0X9",  9,   0X9 );
200     array[item++] = new TestCase( SECTION, "0XA",  10,  0XA );
201     array[item++] = new TestCase( SECTION, "0XB",  11,  0XB );
202     array[item++] = new TestCase( SECTION, "0XC",  12,  0XC );
203     array[item++] = new TestCase( SECTION, "0XD",  13,  0XD );
204     array[item++] = new TestCase( SECTION, "0XE",  14,  0XE );
205     array[item++] = new TestCase( SECTION, "0XF",  15,  0XF );
206
207
208     array[item++] = new TestCase( SECTION, "00",  0,   00 );
209     array[item++] = new TestCase( SECTION, "01",  1,   01 );
210     array[item++] = new TestCase( SECTION, "02",  2,   02 );
211     array[item++] = new TestCase( SECTION, "03",  3,   03 );
212     array[item++] = new TestCase( SECTION, "04",  4,   04 );
213     array[item++] = new TestCase( SECTION, "05",  5,   05 );
214     array[item++] = new TestCase( SECTION, "06",  6,   06 );
215     array[item++] = new TestCase( SECTION, "07",  7,   07 );
216
217     array[item++] = new TestCase( SECTION, "000",  0,   000 );
218     array[item++] = new TestCase( SECTION, "011",  9,   011 );
219     array[item++] = new TestCase( SECTION, "022",  18,  022 );
220     array[item++] = new TestCase( SECTION, "033",  27,  033 );
221     array[item++] = new TestCase( SECTION, "044",  36,  044 );
222     array[item++] = new TestCase( SECTION, "055",  45,  055 );
223     array[item++] = new TestCase( SECTION, "066",  54,  066 );
224     array[item++] = new TestCase( SECTION, "077",  63,   077 );
225
226     array[item++] = new TestCase( SECTION, "0.00000000001",  0.00000000001,  0.00000000001 );
227     array[item++] = new TestCase( SECTION, "0.00000000001e-2",  0.0000000000001,  0.00000000001e-2 );
228
229
230     array[item++] = new TestCase( SECTION,
231                                   "123456789012345671.9999",
232                                   "123456789012345660",
233                                   123456789012345671.9999 +"");
234     array[item++] = new TestCase( SECTION,
235                                "123456789012345672",
236                                "123456789012345660",
237                                123456789012345672 +"");
238
239     array[item++] = new TestCase(   SECTION,
240                                     "123456789012345672.000000000000000000000000000",
241                                    "123456789012345660",
242                                     123456789012345672.000000000000000000000000000 +"");
243
244     array[item++] = new TestCase( SECTION,
245            "123456789012345672.01",
246            "123456789012345680",
247            123456789012345672.01 +"");
248
249     array[item++] = new TestCase( SECTION,
250            "123456789012345672.000000000000000000000000001+'' == 123456789012345680 || 123456789012345660",
251            true,
252            ( 123456789012345672.00000000000000000000000000 +""  == 1234567890 * 100000000 + 12345680 )
253            ||
254            ( 123456789012345672.00000000000000000000000000 +""  == 1234567890 * 100000000 + 12345660) );
255
256     array[item++] = new TestCase( SECTION,
257            "123456789012345673",
258            "123456789012345680",
259            123456789012345673 +"" );
260
261     array[item++] = new TestCase( SECTION,
262            "-123456789012345671.9999",
263            "-123456789012345660",
264            -123456789012345671.9999 +"" );
265
266     array[item++] = new TestCase( SECTION,
267            "-123456789012345672",
268            "-123456789012345660",
269            -123456789012345672+"");
270
271     array[item++] = new TestCase( SECTION,
272            "-123456789012345672.000000000000000000000000000",
273            "-123456789012345660",
274            -123456789012345672.000000000000000000000000000 +"");
275
276     array[item++] = new TestCase( SECTION,
277            "-123456789012345672.01",
278            "-123456789012345680",
279            -123456789012345672.01 +"" );
280
281     array[item++] = new TestCase( SECTION,
282            "-123456789012345672.000000000000000000000000001 == -123456789012345680 or -123456789012345660",
283            true,
284            (-123456789012345672.000000000000000000000000001 +"" == -1234567890 * 100000000 -12345680)
285            ||
286            (-123456789012345672.000000000000000000000000001 +"" == -1234567890 * 100000000 -12345660));
287
288     array[item++] = new TestCase( SECTION,
289            -123456789012345673,
290            "-123456789012345680",
291            -123456789012345673 +"");
292
293     array[item++] = new TestCase( SECTION,
294            "12345678901234567890",
295            "12345678901234567000",
296            12345678901234567890 +"" );
297
298
299 /*
300     array[item++] = new TestCase( SECTION, "12345678901234567",         "12345678901234567",        12345678901234567+"" );
301     array[item++] = new TestCase( SECTION, "123456789012345678",        "123456789012345678",       123456789012345678+"" );
302     array[item++] = new TestCase( SECTION, "1234567890123456789",       "1234567890123456789",      1234567890123456789+"" );
303     array[item++] = new TestCase( SECTION, "12345678901234567890",      "12345678901234567890",     12345678901234567890+"" );
304     array[item++] = new TestCase( SECTION, "123456789012345678900",     "123456789012345678900",    123456789012345678900+"" );
305     array[item++] = new TestCase( SECTION, "1234567890123456789000",    "1234567890123456789000",   1234567890123456789000+"" );
306 */
307     array[item++] =  new TestCase( SECTION, "0x1",          1,          0x1 );
308     array[item++] =  new TestCase( SECTION, "0x10",         16,         0x10 );
309     array[item++] =  new TestCase( SECTION, "0x100",        256,        0x100 );
310     array[item++] =  new TestCase( SECTION, "0x1000",       4096,       0x1000 );
311     array[item++] =  new TestCase( SECTION, "0x10000",      65536,      0x10000 );
312     array[item++] =  new TestCase( SECTION, "0x100000",     1048576,    0x100000 );
313     array[item++] =  new TestCase( SECTION, "0x1000000",    16777216,   0x1000000 );
314     array[item++] =  new TestCase( SECTION, "0x10000000",   268435456,  0x10000000 );
315 /*
316     array[item++] =  new TestCase( SECTION, "0x100000000",          4294967296,      0x100000000 );
317     array[item++] =  new TestCase( SECTION, "0x1000000000",         68719476736,     0x1000000000 );
318     array[item++] =  new TestCase( SECTION, "0x10000000000",        1099511627776,     0x10000000000 );
319 */
320     return ( array );
321 }
322
323 function test() {
324         for ( tc=0; tc < testcases.length; tc++ ) {
325             testcases[tc].actual = testcases[tc].actual;
326
327             testcases[tc].passed = writeTestCaseResult(
328                             testcases[tc].expect,
329                             testcases[tc].actual,
330                             testcases[tc].description +" = "+ testcases[tc].actual );
331
332             testcases[tc].reason += ( testcases[tc].passed ) ? "" : "wrong value ";
333
334         }
335
336         stopTest();
337         return ( testcases );
338 }