Imported Upstream version 1.0.0
[platform/upstream/js.git] / js / src / tests / ecma / TypeConversion / 9.3.1-2.js
1 /* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3  * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4  *
5  * The contents of this file are subject to the Mozilla Public License Version
6  * 1.1 (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  * http://www.mozilla.org/MPL/
9  *
10  * Software distributed under the License is distributed on an "AS IS" basis,
11  * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12  * for the specific language governing rights and limitations under the
13  * License.
14  *
15  * The Original Code is Mozilla Communicator client code, released
16  * March 31, 1998.
17  *
18  * The Initial Developer of the Original Code is
19  * Netscape Communications Corporation.
20  * Portions created by the Initial Developer are Copyright (C) 1998
21  * the Initial Developer. All Rights Reserved.
22  *
23  * Contributor(s):
24  *
25  * Alternatively, the contents of this file may be used under the terms of
26  * either the GNU General Public License Version 2 or later (the "GPL"), or
27  * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
28  * in which case the provisions of the GPL or the LGPL are applicable instead
29  * of those above. If you wish to allow use of your version of this file only
30  * under the terms of either the GPL or the LGPL, and not to allow others to
31  * use your version of this file under the terms of the MPL, indicate your
32  * decision by deleting the provisions above and replace them with the notice
33  * and other provisions required by the GPL or the LGPL. If you do not delete
34  * the provisions above, a recipient may use your version of this file under
35  * the terms of any one of the MPL, the GPL or the LGPL.
36  *
37  * ***** END LICENSE BLOCK ***** */
38
39
40 /**
41    File Name:          9.3.1-2.js
42    ECMA Section:       9.3  Type Conversion:  ToNumber
43    Description:        rules for converting an argument to a number.
44    see 9.3.1 for cases for converting strings to numbers.
45    special cases:
46    undefined           NaN
47    Null                NaN
48    Boolean             1 if true; +0 if false
49    Number              the argument ( no conversion )
50    String              see test 9.3.1
51    Object              see test 9.3-1
52
53    This tests special cases of ToNumber(string) that are
54    not covered in 9.3.1-1.js.
55
56    Author:             christine@netscape.com
57    Date:               10 july 1997
58
59 */
60 var SECTION = "9.3.1-2";
61 var VERSION = "ECMA_1";
62 startTest();
63 var TITLE   = "ToNumber applied to the String type";
64
65 writeHeaderToLog( SECTION + " "+ TITLE);
66
67 // A StringNumericLiteral may not use octal notation
68
69 new TestCase( SECTION,  "Number(00)",        0,         Number("00"));
70 new TestCase( SECTION,  "Number(01)",        1,         Number("01"));
71 new TestCase( SECTION,  "Number(02)",        2,         Number("02"));
72 new TestCase( SECTION,  "Number(03)",        3,         Number("03"));
73 new TestCase( SECTION,  "Number(04)",        4,         Number("04"));
74 new TestCase( SECTION,  "Number(05)",        5,         Number("05"));
75 new TestCase( SECTION,  "Number(06)",        6,         Number("06"));
76 new TestCase( SECTION,  "Number(07)",        7,         Number("07"));
77 new TestCase( SECTION,  "Number(010)",       10,        Number("010"));
78 new TestCase( SECTION,  "Number(011)",       11,        Number("011"));
79
80 // A StringNumericLIteral may have any number of leading 0 digits
81
82 new TestCase( SECTION,  "Number(001)",        1,         Number("001"));
83 new TestCase( SECTION,  "Number(0001)",       1,         Number("0001"));
84
85 test();
86