Imported Upstream version 1.0.0
[platform/upstream/js.git] / js / src / tests / js1_5 / Array / regress-101964.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.org code.
16  *
17  * The Initial Developer of the Original Code is
18  * Netscape Communications Corporation.
19  * Portions created by the Initial Developer are Copyright (C) 1998
20  * the Initial Developer. All Rights Reserved.
21  *
22  * Contributor(s):
23  *   pschwartau@netscape.com
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  * Date: 27 September 2001
41  *
42  * SUMMARY: Performance: truncating even very large arrays should be fast!
43  * See http://bugzilla.mozilla.org/show_bug.cgi?id=101964
44  *
45  * Adjust this testcase if necessary. The FAST constant defines
46  * an upper bound in milliseconds for any truncation to take.
47  */
48 //-----------------------------------------------------------------------------
49 var UBound = 0;
50 var BUGNUMBER = 101964;
51 var summary = 'Performance: truncating even very large arrays should be fast!';
52 var BIG = 10000000;
53 var LITTLE = 10;
54 var FAST = 50; // array truncation should be 50 ms or less to pass the test
55 var MSG_FAST = 'Truncation took less than ' + FAST + ' ms';
56 var MSG_SLOW = 'Truncation took ';
57 var MSG_MS = ' ms';
58 var status = '';
59 var statusitems = [];
60 var actual = '';
61 var actualvalues = [];
62 var expect= '';
63 var expectedvalues = [];
64
65
66
67 status = inSection(1);
68 var arr = Array(BIG);
69 var start = new Date();
70 arr.length = LITTLE;
71 actual = elapsedTime(start);
72 expect = FAST;
73 addThis();
74
75
76
77 //-----------------------------------------------------------------------------
78 test();
79 //-----------------------------------------------------------------------------
80
81
82
83 function elapsedTime(startTime)
84 {
85   return new Date() - startTime;
86 }
87
88
89 function addThis()
90 {
91   statusitems[UBound] = status;
92   actualvalues[UBound] = isThisFast(actual);
93   expectedvalues[UBound] = isThisFast(expect);
94   UBound++;
95 }
96
97
98 function isThisFast(ms)
99 {
100   if (ms <= FAST)
101     return MSG_FAST;
102   return MSG_SLOW + ms + MSG_MS;
103 }
104
105
106 function test()
107 {
108   enterFunc ('test');
109   printBugNumber(BUGNUMBER);
110   printStatus (summary);
111
112   for (var i=0; i<UBound; i++)
113   {
114     reportCompare(expectedvalues[i], actualvalues[i], statusitems[i]);
115   }
116
117   exitFunc ('test');
118 }