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 startup;
043:
044: import org.netbeans.jellytools.actions.OpenAction;
045: import org.netbeans.jellytools.nodes.Node;
046: import org.netbeans.jemmy.operators.*;
047: import junit.framework.Test;
048: import junit.framework.TestSuite;
049: import org.netbeans.jellytools.Bundle;
050: import org.netbeans.jellytools.JellyTestCase;
051: import org.netbeans.jellytools.NbDialogOperator;
052: import org.netbeans.jellytools.ProjectsTabOperator;
053:
054: import org.netbeans.junit.NbTestSuite;
055: import org.netbeans.junit.ide.ProjectSupport;
056:
057: /**
058: * Prepare user directory for measurement of startup time of IDE with opened files.
059: * Open 10 java files and shut down ide.
060: * Created user directory will be used to measure startup time of IDE with opened files.
061: *
062: * @author Marian.Mirilovic@sun.com
063: */
064: public class MeasureJ2EEStartupTimeOpenedFilesPrepare extends
065: JellyTestCase {
066:
067: /** Define testcase
068: * @param testName name of the testcase
069: */
070: public MeasureJ2EEStartupTimeOpenedFilesPrepare(String testName) {
071: super (testName);
072: }
073:
074: /** Testsuite
075: * @return testuite
076: */
077: public static Test suite() {
078: TestSuite suite = new NbTestSuite();
079: suite.addTest(new IDESetupTest("testCloseMemoryToolbar"));
080: suite.addTest(new IDESetupTest("closeAllDocuments"));
081: suite.addTest(new IDESetupTest("testAddAppServer"));
082: suite.addTest(new MeasureJ2EEStartupTimeOpenedFilesPrepare(
083: "testOpenProjects"));
084: suite.addTest(new MeasureJ2EEStartupTimeOpenedFilesPrepare(
085: "openFiles"));
086: return suite;
087: }
088:
089: @Override
090: public void setUp() {
091: System.out.println("######## " + getName() + " ########");
092: }
093:
094: public void testOpenProjects() {
095: ProjectSupport.openProject(System.getProperty("xtest.tmpdir")
096: + "/startup/TestStartupApp");
097: ProjectSupport.waitScanFinished();
098: ProjectSupport.openProject(System.getProperty("xtest.tmpdir")
099: + "/startup/TestStartupApp/TestStartupApp-ejb");
100: ProjectSupport.waitScanFinished();
101: ProjectSupport.openProject(System.getProperty("xtest.tmpdir")
102: + "/startup/TestStartupApp/TestStartupApp-war");
103: ProjectSupport.waitScanFinished();
104: ProjectSupport.openProject(System.getProperty("xtest.tmpdir")
105: + "/startup/TestStartupEJB1");
106: ProjectSupport.waitScanFinished();
107: ProjectSupport.openProject(System.getProperty("xtest.tmpdir")
108: + "/startup/TestStartupEJB2");
109: ProjectSupport.waitScanFinished();
110: //waitForScan();
111: }
112:
113: private void waitForScan() {
114: // "Scanning Project Classpaths"
115: String titleScanning = Bundle.getString(
116: "org.netbeans.modules.javacore.Bundle",
117: "TXT_ApplyingPathsTitle");
118: NbDialogOperator scanningDialogOper = new NbDialogOperator(
119: titleScanning);
120: // scanning can last for a long time => wait max. 5 minutes
121: scanningDialogOper.getTimeouts().setTimeout(
122: "ComponentOperator.WaitStateTimeout", 300000);
123: scanningDialogOper.waitClosed();
124: }
125:
126: /**
127: * Open 10 selected files from jEdit project.
128: */
129: public void openFiles() {
130:
131: new org.netbeans.jemmy.EventTool().waitNoEvent(10000);
132:
133: String[][] files_path = {
134: { "TestStartupApp",
135: "Configuration Files|sun-application.xml" },
136: { "TestStartupApp-EJB",
137: "Enterprise Beans|TestSessionSB" },
138: { "TestStartupApp-EJB",
139: "Configuration Files|ejb-jar.xml" },
140: { "TestStartupApp-EJB",
141: "Configuration Files|sun-ejb-jar.xml" },
142: { "TestStartupApp-WAR", "Web Pages|index.jsp" },
143: { "TestStartupApp-WAR", "Configuration Files|web.xml" },
144: { "TestStartupApp-WAR",
145: "Configuration Files|sun-web.xml" },
146: { "TestStartupApp-WAR",
147: "Source Packages|test|TestServlet.java" },
148: { "TestStartupEJB1", "Enterprise Beans|TestSession2SB" },
149: { "TestStartupEJB1", "Enterprise Beans|TestMessageMDB" },
150: { "TestStartupEJB1", "Enterprise Beans|TestEntityEB" },
151: // TODO - uncomment when Web Services node becomes fixed
152: // {"TestStartupEJB2","Web Services|TestWebService1"},
153: // {"TestStartupEJB2","Web Services|TestWebService2"}
154: };
155:
156: Node[] openFileNodes = new Node[files_path.length];
157:
158: for (int i = 0; i < files_path.length; i++) {
159: Node root = new ProjectsTabOperator()
160: .getProjectRootNode(files_path[i][0]);
161: root.setComparator(new Operator.DefaultStringComparator(
162: true, true));
163: openFileNodes[i] = new Node(root, files_path[i][1]);
164: // open file one by one, opening all files at once causes never ending loop (java+mdr)
165: //new OpenAction().performAPI(openFileNodes[i]);
166: }
167:
168: // try to come back and open all files at-once, rises another problem with refactoring, if you do open file and next expand folder,
169: // it doesn't finish in the real-time -> hard to reproduced by hand
170: new OpenAction().performAPI(openFileNodes);
171:
172: new org.netbeans.jemmy.EventTool().waitNoEvent(60000);
173:
174: }
175:
176: public static void main(java.lang.String[] args) {
177: junit.textui.TestRunner.run(suite());
178: }
179: }
|