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-2007 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 gui.action;
043:
044: import gui.VWPUtilities;
045:
046: import org.netbeans.jellytools.MainWindowOperator;
047: import org.netbeans.jellytools.ProjectsTabOperator;
048: import org.netbeans.jellytools.nodes.Node;
049:
050: import org.netbeans.jemmy.operators.ComponentOperator;
051: import org.netbeans.jemmy.operators.JPopupMenuOperator;
052:
053: /**
054: *
055: * @author mkhramov@netbeans.org, mmirilovic@netbeans.org
056: */
057: public class WebProjectDeployment extends
058: org.netbeans.performance.test.utilities.PerformanceTestCase {
059: private String targetProject;
060: private Node proj;
061: private JPopupMenuOperator projectMenu;
062:
063: /**
064: * Creates a new instance of WebProjectDeployment
065: */
066: public WebProjectDeployment(String testName) {
067: super (testName);
068: expectedTime = 10000;
069: WAIT_AFTER_OPEN = 60000;
070: }
071:
072: public WebProjectDeployment(String testName,
073: String performanceDataName) {
074: super (testName, performanceDataName);
075: expectedTime = 10000;
076: WAIT_AFTER_OPEN = 60000;
077: }
078:
079: public void testDeploySmallProject() {
080: targetProject = "VisualWebProject";
081: doMeasurement();
082: }
083:
084: public void testDeployLargeProject() {
085: targetProject = "HugeApp";
086: doMeasurement();
087: }
088:
089: public void initialize() {
090: log("::initialize");
091: VWPUtilities.initLog(this );
092: String asName = org.netbeans.jellytools.Bundle.getString(
093: "org.netbeans.modules.j2ee.sun.ide.dm.Bundle",
094: "FACTORY_DISPLAYNAME");
095: log("Applications server node name from bundle is: " + asName
096: + " ??");
097: long start = System.currentTimeMillis();
098:
099: VWPUtilities.startApplicationServer();
100: long stop = System.currentTimeMillis();
101:
102: log("App server started in " + (stop - start) + " ms");
103:
104: ProjectsTabOperator.invoke();
105: VWPUtilities.verifyAndResolveMissingWebServer(targetProject,
106: asName);
107: VWPUtilities.waitForPendingBackgroundTasks();
108:
109: VWPUtilities.buildproject(targetProject);
110: VWPUtilities.waitForPendingBackgroundTasks();
111:
112: }
113:
114: public void prepare() {
115: log(":: prepare");
116: proj = null;
117: try {
118: proj = new ProjectsTabOperator()
119: .getProjectRootNode(targetProject);
120: proj.select();
121:
122: } catch (org.netbeans.jemmy.TimeoutExpiredException ex) {
123: fail("Cannot find and select project root node");
124: }
125: projectMenu = proj.callPopup();
126: }
127:
128: public ComponentOperator open() {
129: log(":: open");
130: projectMenu.pushMenuNoBlock(org.netbeans.jellytools.Bundle
131: .getString(
132: "org.netbeans.modules.web.project.ui.Bundle",
133: "LBL_RedeployAction_Name"));
134:
135: VWPUtilities.waitForPendingBackgroundTasks();
136: String statusText = "Finished building " + targetProject
137: + " (run-deploy)."; // NOI18N
138: log("Waiting for: '" + statusText + "' text in status bar");
139: MainWindowOperator.getDefault().waitStatusText(statusText);
140:
141: return null;
142: }
143:
144: public void close() {
145: //TODO Undeploy?
146: }
147:
148: public void shutdown() {
149: log(":: shutdown ");
150: VWPUtilities.stopApplicationServer();
151: VWPUtilities.closeLog();
152: }
153: }
|