001: /*
002: * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
003: *
004: * Copyright 1997-2007 Sun Microsystems, Inc. All rights reserved.
005: *
006: * The contents of this file are subject to the terms of either the GNU
007: * General Public License Version 2 only ("GPL") or the Common
008: * Development and Distribution License("CDDL") (collectively, the
009: * "License"). You may not use this file except in compliance with the
010: * License. You can obtain a copy of the License at
011: * http://www.netbeans.org/cddl-gplv2.html
012: * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
013: * specific language governing permissions and limitations under the
014: * License. When distributing the software, include this License Header
015: * Notice in each file and include the License file at
016: * nbbuild/licenses/CDDL-GPL-2-CP. Sun designates this
017: * particular file as subject to the "Classpath" exception as provided
018: * by Sun in the GPL Version 2 section of the License file that
019: * accompanied this code. If applicable, add the following below the
020: * License Header, with the fields enclosed by brackets [] replaced by
021: * your own identifying information:
022: * "Portions Copyrighted [year] [name of copyright owner]"
023: *
024: * Contributor(s):
025: *
026: * The Original Software is NetBeans. The Initial Developer of the Original
027: * Software is Sun Microsystems, Inc. Portions Copyright 1997-2006 Sun
028: * Microsystems, Inc. All Rights Reserved.
029: *
030: * If you wish your version of this file to be governed by only the CDDL
031: * or only the GPL Version 2, indicate your decision by adding
032: * "[Contributor] elects to include this software in this distribution
033: * under the [CDDL or GPL Version 2] license." If you do not indicate a
034: * single choice of license, a recipient has the option to distribute
035: * your version of this file under either the CDDL, the GPL Version 2 or
036: * to extend the choice of license to its licensees as provided above.
037: * However, if you add GPL Version 2 code and therefore, elected the GPL
038: * Version 2 license, then the option applies only if the new code is
039: * made subject to such option by the copyright holder.
040: */
041:
042: package org.netbeans.junit;
043:
044: import java.util.ArrayList;
045: import java.util.List;
046:
047: /** Default implementation of NbPerformanceTest with added methods to collect
048: * measured performance data.
049: * @author <a href="mailto:adam.sotona@sun.com">Adam Sotona</a>
050: */
051: public class NbPerformanceTestCase extends NbTestCase implements
052: NbPerformanceTest {
053:
054: /** Creates a new instance of NbPerformanceTestCase
055: * @param name String test name
056: */
057: public NbPerformanceTestCase(String name) {
058: super (name);
059: }
060:
061: private List<NbPerformanceTest.PerformanceData> data = new ArrayList<NbPerformanceTest.PerformanceData>();
062:
063: /** getter for all measured performance data from current test
064: * @return PerformanceData[]
065: */
066: public NbPerformanceTest.PerformanceData[] getPerformanceData() {
067: return data.toArray(new NbPerformanceTest.PerformanceData[0]);
068: }
069:
070: /** method for storing and reporting measured performance value,
071: * test case name is used as value name and unit is not specified
072: * @param value measured perofrmance value
073: */
074: public void reportPerformance(long value) {
075: reportPerformance(null, value, null,
076: NbPerformanceTest.PerformanceData.NO_ORDER);
077: }
078:
079: /** method for storing and reporting measured performance value,
080: * test case name is used as value name
081: * @param value measured perofrmance value
082: * @param unit unit name of measured value
083: */
084: public void reportPerformance(long value, String unit) {
085: reportPerformance(null, value, unit,
086: NbPerformanceTest.PerformanceData.NO_ORDER);
087: }
088:
089: /** method for storing and reporting measured performance value,
090: * unit is not specified
091: * @param name measured value name
092: * @param value measured perofrmance value
093: */
094: public void reportPerformance(String name, long value) {
095: reportPerformance(name, value, null,
096: NbPerformanceTest.PerformanceData.NO_ORDER);
097: }
098:
099: /** method for storing and reporting measured performance value
100: * @param name measured value name
101: * @param value measured perofrmance value
102: * @param unit unit name of measured value
103: * @param runOrder order in which the data was measured (1st, 2nd, ...)
104: */
105: public void reportPerformance(String name, long value, String unit,
106: int runOrder) {
107: reportPerformance(name, value, unit, runOrder,
108: PerformanceData.NO_THRESHOLD);
109: }
110:
111: /** method for storing and reporting measured performance value
112: * @param name measured value name
113: * @param value measured perofrmance value
114: * @param unit unit name of measured value
115: * @param runOrder order in which the data was measured (1st, 2nd, ...)
116: * @param threshold - measure threshold
117: */
118: public void reportPerformance(String name, long value, String unit,
119: int runOrder, long threshold) {
120: NbPerformanceTest.PerformanceData d = new NbPerformanceTest.PerformanceData();
121: d.name = name == null ? getName() : name;
122: d.value = value;
123: d.unit = unit;
124: d.runOrder = runOrder;
125: d.threshold = threshold;
126: data.add(d);
127: }
128:
129: }
|