KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > com > jcorporate > expresso > ext > tests > RetrieveThroughputTest


1 /* ====================================================================
2  * The Jcorporate Apache Style Software License, Version 1.2 05-07-2002
3  *
4  * Copyright (c) 1995-2002 Jcorporate Ltd. All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions
8  * are met:
9  *
10  * 1. Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  *
13  * 2. Redistributions in binary form must reproduce the above copyright
14  * notice, this list of conditions and the following disclaimer in
15  * the documentation and/or other materials provided with the
16  * distribution.
17  *
18  * 3. The end-user documentation included with the redistribution,
19  * if any, must include the following acknowledgment:
20  * "This product includes software developed by Jcorporate Ltd.
21  * (http://www.jcorporate.com/)."
22  * Alternately, this acknowledgment may appear in the software itself,
23  * if and wherever such third-party acknowledgments normally appear.
24  *
25  * 4. "Jcorporate" and product names such as "Expresso" must
26  * not be used to endorse or promote products derived from this
27  * software without prior written permission. For written permission,
28  * please contact info@jcorporate.com.
29  *
30  * 5. Products derived from this software may not be called "Expresso",
31  * or other Jcorporate product names; nor may "Expresso" or other
32  * Jcorporate product names appear in their name, without prior
33  * written permission of Jcorporate Ltd.
34  *
35  * 6. No product derived from this software may compete in the same
36  * market space, i.e. framework, without prior written permission
37  * of Jcorporate Ltd. For written permission, please contact
38  * partners@jcorporate.com.
39  *
40  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
41  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
42  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
43  * DISCLAIMED. IN NO EVENT SHALL JCORPORATE LTD OR ITS CONTRIBUTORS
44  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
45  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
46  * TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
47  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
48  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
49  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
50  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
51  * SUCH DAMAGE.
52  * ====================================================================
53  *
54  * This software consists of voluntary contributions made by many
55  * individuals on behalf of the Jcorporate Ltd. Contributions back
56  * to the project(s) are encouraged when you make modifications.
57  * Please send them to support@jcorporate.com. For more information
58  * on Jcorporate Ltd. and its products, please see
59  * <http://www.jcorporate.com/>.
60  *
61  * Portions of this software are based upon other open source
62  * products and are subject to their respective licenses.
63  */

64
65 package com.jcorporate.expresso.ext.tests;
66
67 import com.jcorporate.expresso.core.dbobj.SecuredDBObject;
68 import com.jcorporate.expresso.core.misc.ConfigManager;
69 import com.jcorporate.expresso.core.misc.ConfigurationException;
70 import com.jcorporate.expresso.services.dbobj.DefaultUserInfo;
71 import com.jcorporate.expresso.services.dbobj.MimeTypes;
72 import com.jcorporate.expresso.services.test.ExpressoTestCase;
73 import com.jcorporate.expresso.services.test.TestSystemInitializer;
74 import junit.framework.TestSuite;
75
76 /**
77  * <p>Title: </p>
78  * <p>Description: </p>
79  * <p>Copyright: </p>
80  * <p>Company: </p>
81  *
82  * @author Michael Rimov
83  * @version $Revision: 1.2 $ on $Date: 2004/11/17 20:48:23 $
84  */

85
86 public class RetrieveThroughputTest extends ExpressoTestCase {
87     static final int NUM_ITERATIONS = 1000;
88     private long startTime = 0;
89
90
91     public RetrieveThroughputTest(String JavaDoc testName)
92             throws Exception JavaDoc {
93         super(testName);
94     }
95
96     public static void main(String JavaDoc[] args)
97             throws Exception JavaDoc {
98
99         //Set the system properties we need
100
junit.textui.TestRunner.run(suite());
101     }
102
103     /**
104      * Define the suite of tests that verify each function of the cache
105      *
106      * @return
107      */

108     public static junit.framework.Test suite() {
109         TestSuite suite = new TestSuite(RetrieveThroughputTest.class);
110
111         return suite;
112     } /* suite() */
113
114     /**
115      * Sets up the fixture, for example, open a network connection.
116      * This method is called before a test is executed.
117      */

118     protected void setUp()
119             throws Exception JavaDoc {
120         TestSystemInitializer.setUp();
121         try {
122             ConfigManager.getContext(TestSystemInitializer.getTestContext());
123         } catch (ConfigurationException ce) {
124             fail("There is no 'test' db/context set up - cannot run db object tests without a test context");
125         }
126
127 // StressTestSchema ts = new StressTestSchema();
128
// SchemaCreator.ensureSchemaExists(new com.jcorporate.expresso.core.ExpressoSchema());
129
// SchemaCreator.ensureSchemaExists(ts);
130
startTime = new java.util.Date JavaDoc().getTime();
131     } /* setUp() */
132
133     public void testRetrieve() {
134         try {
135             MimeTypes mt = new MimeTypes(SecuredDBObject.SYSTEM_ACCOUNT);
136             mt.setDataContext(TestSystemInitializer.getTestContext());
137             mt.setField(MimeTypes.FLD_MIMENUMBER, 1);
138             mt.retrieve();
139             startTime = System.currentTimeMillis();
140             for (int i = 0; i < NUM_ITERATIONS; i++) {
141                 mt.retrieve();
142             }
143             long endTime = System.currentTimeMillis();
144             System.out.println(
145                     "Throughput for retrieving MimeTypes was: " + (endTime - startTime) / NUM_ITERATIONS + " ms per retrieval");
146
147
148             DefaultUserInfo dui = new DefaultUserInfo(SecuredDBObject.SYSTEM_ACCOUNT);
149             dui.setDataContext(TestSystemInitializer.getTestContext());
150             dui.setField(DefaultUserInfo.EXPUID, 3);
151             dui.retrieve();
152             startTime = System.currentTimeMillis();
153             for (int i = 0; i < NUM_ITERATIONS; i++) {
154                 dui.retrieve();
155             }
156             endTime = System.currentTimeMillis();
157             System.out.println(
158                     "Throughput for retrieving DefaultUserInfo was: " + (endTime - startTime) / NUM_ITERATIONS + " ms per retrieval");
159
160         } catch (Exception JavaDoc e) {
161             e.printStackTrace();
162             fail("Exception caught while testing");
163         }
164
165     }
166
167 }
Popular Tags