* roottypes.cs: Rename from tree.cs.
[mono.git] / mcs / class / Microsoft.JScript / Test / Mozilla / js1_2 / Array / slice.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    Filename:     slice.js
41    Description:  'This tests out some of the functionality on methods on the Array objects'
42
43    Author:       Nick Lerissa
44    Date:         Fri Feb 13 09:58:28 PST 1998
45 */
46
47 var SECTION = 'As described in Netscape doc "Whats new in JavaScript 1.2"';
48 var VERSION = 'no version';
49 startTest();
50 var TITLE = 'String:slice';
51
52 writeHeaderToLog('Executing script: slice.js');
53 writeHeaderToLog( SECTION + " "+ TITLE);
54         
55 var a = ['a','test string',456,9.34,new String("string object"),[],['h','i','j','k']];
56 var b = [1,2,3,4,5,6,7,8,9,0];
57         
58 exhaustiveSliceTest("exhaustive slice test 1", a);
59 exhaustiveSliceTest("exhaustive slice test 2", b);
60         
61 test();
62
63 function mySlice(a, from, to)
64 {
65     var from2       = from;
66     var to2         = to;
67     var returnArray = [];
68     var i;
69         
70     if (from2 < 0) from2 = a.length + from;
71     if (to2 < 0)   to2   = a.length + to;
72         
73     if ((to2 > from2)&&(to2 > 0)&&(from2 < a.length))
74     {
75         if (from2 < 0)        from2 = 0;
76         if (to2 > a.length) to2 = a.length;
77         
78         for (i = from2; i < to2; ++i) returnArray.push(a[i]);
79     }
80     return returnArray;
81 }
82         
83 // This function tests the slice command on an Array
84 // passed in. The arguments passed into slice range in
85 // value from -5 to the length of the array + 4. Every
86 // combination of the two arguments is tested. The expected
87 // result of the slice(...) method is calculated and
88 // compared to the actual result from the slice(...) method.
89 // If the Arrays are not similar false is returned.
90 function exhaustiveSliceTest(testname, a)
91 {
92     var x = 0;
93     var y = 0;
94     var errorMessage;
95     var reason = "";
96     var passed = true;
97         
98     for (x = -(2 + a.length); x <= (2 + a.length); x++)
99         for (y = (2 + a.length); y >= -(2 + a.length); y--)
100         {
101             var b  = a.slice(x,y);
102             var c = mySlice(a,x,y);
103         
104             if (String(b) != String(c))
105             {
106                 errorMessage =
107                     "ERROR: 'TEST FAILED' ERROR: 'TEST FAILED' ERROR: 'TEST FAILED'\n" +
108                     "            test: " + "a.slice(" + x + "," + y + ")\n" +
109                     "               a: " + String(a) + "\n" +
110                     "   actual result: " + String(b) + "\n" +
111                     " expected result: " + String(c) + "\n";
112                 writeHeaderToLog(errorMessage);
113                 reason = reason + errorMessage;
114                 passed = false;
115             }
116         }
117     var testCase = new TestCase(SECTION, testname, true, passed);
118     if (passed == false)
119         testCase.reason = reason;
120     return testCase;
121 }