Imported Upstream version 1.0.0
[platform/upstream/js.git] / js / src / tests / js1_5 / extensions / regress-335700.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 JavaScript Engine testing utilities.
16  *
17  * The Initial Developer of the Original Code is
18  * Mozilla Foundation.
19  * Portions created by the Initial Developer are Copyright (C) 2006
20  * the Initial Developer. All Rights Reserved.
21  *
22  * Contributor(s): Charles Verdon
23  *                 Brendan Eich
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 var BUGNUMBER = 335700;
41 var summary = 'Object Construction with getter closures should be O(N)';
42 var actual = '';
43 var expect = '';
44
45 printBugNumber(BUGNUMBER);
46 printStatus (summary);
47  
48 test('Object', Object);
49 test('ObjectWithFunction', ObjectWithFunction);
50 test('ObjectWithGetter', ObjectWithGetter);
51
52 function test(desc, ctor)
53 {
54   var start = 00000;
55   var stop  = 40000;
56   var incr  = (stop - start)/10;
57
58   desc = summary + ': ' + desc;
59
60   var data = {X:[], Y:[]};
61   for (var i = start; i <= stop; i += incr)
62   { 
63     data.X.push(i);
64     data.Y.push(runStart(ctor, i));
65     gc();
66   }
67
68   var order = BigO(data);
69
70   var msg = '';
71   for (var p = 0; p < data.X.length; p++)
72   {
73     msg += '(' + data.X[p] + ', ' + data.Y[p] + '); ';
74   }
75
76   print(msg);
77  
78   reportCompare(true, order < 2, desc + ': BigO ' + order + ' < 2');
79
80 }
81
82 function ObjectWithFunction()
83 {
84   var m_var = null;
85   this.init = function(p_var) {
86     m_var = p_var;
87   }
88   this.getVar = function()
89     {
90       return m_var;
91     }
92   this.setVar = function(v)
93     {
94       m_var = v;
95     }
96 }
97 function ObjectWithGetter()
98 {
99   var m_var = null;
100   this.init = function(p_var) {
101     m_var = p_var;
102   }
103   this.Var getter = function() {
104     return m_var;
105   }
106   this.Var setter = function(v) {
107     m_var = v;
108   }
109 }
110
111 function runStart(ctor, limit)
112 {
113   var arr = [];
114   var start = Date.now();
115
116   for (var i=0; i < limit; i++) {
117     var obj = new ctor();
118     obj.Var = 42;
119     arr.push(obj);
120   }
121
122   var end = Date.now();
123   var diff = end - start;
124
125   return diff;
126 }