/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 2010-2011 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
package org.glassfish.admingui.devtests;
import org.junit.Test;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertTrue;
public class JdbcTest extends BaseSeleniumTestClass {
public static final String TRIGGER_JDBC_CONNECTION_POOLS = "i18njdbc.jdbcConnectionPools.pageTitleHelp";
public static final String TRIGGER_EDIT_JDBC_CONNECTION_POOL = "i18njdbc.jdbcConnection.editPageHelp";
public static final String TRIGGER_ADVANCE_JDBC_CONNECTION_POOL = "i18njdbc.jdbcConnectionPool.advancePageTitleHelp";
public static final String TRIGGER_PROPS_JDBC_CONNECTION_POOL = "i18njdbc.jdbcConnectionPool.propertyPageTitleHelp";
public static final String TRIGGER_JDBC_RESOURCES = "i18njdbc.jdbcResources.pageTitleHelp";
public static final String TRIGGER_EDIT_JDBC_RESOURCE = "i18njdbc.jdbcResource.editPageTitleHelp";
public static final String TRIGGER_NEW_JDBC_CONNECTION_POOL_STEP_1 = "i18njdbc.jdbcConnection.step1PageHelp";
public static final String TRIGGER_NEW_JDBC_CONNECTION_POOL_STEP_2 = "i18njdbc.jdbcConnection.step2PageHelp";
public static final String TRIGGER_NEW_JDBC_RESOURCE = "i18njdbc.jdbcResource.newPageTitleHelp";
@Test
public void testPoolPing() {
clickAndWait("treeForm:tree:resources:JDBC:connectionPoolResources:__TimerPool:link", "Edit JDBC Connection Pool");
clickAndWait("propertyForm:propertyContentPage:ping", "Ping Succeeded");
}
@Test
public void testCreatingConnectionPool() {
final String poolName = "jdbcPool" + generateRandomString();
final String description = "devtest test connection pool - " + poolName;
clickAndWait("treeForm:tree:resources:JDBC:connectionPoolResources:connectionPoolResources_link", TRIGGER_JDBC_CONNECTION_POOLS);
clickAndWait("propertyForm:poolTable:topActionsGroup1:newButton", TRIGGER_NEW_JDBC_CONNECTION_POOL_STEP_1);
setFieldValue("propertyForm:propertyContentPage:propertySheet:generalPropertySheet:jndiProp:name", poolName);
selectDropdownOption("propertyForm:propertyContentPage:propertySheet:generalPropertySheet:resTypeProp:resType", "javax.sql.DataSource");
selectDropdownOption("propertyForm:propertyContentPage:propertySheet:generalPropertySheet:dbProp:db", "Derby");
clickAndWait("propertyForm:propertyContentPage:topButtons:nextButton", TRIGGER_NEW_JDBC_CONNECTION_POOL_STEP_2);
setFieldValue("form2:sheet:generalSheet:descProp:desc", description);
clickAndWait("form2:propertyContentPage:topButtons:finishButton", TRIGGER_JDBC_CONNECTION_POOLS);
assertTrue(isTextPresent(poolName) && isTextPresent(description));
deleteRow("propertyForm:poolTable:topActionsGroup1:button1", "propertyForm:poolTable", poolName);
}
@Test
public void testCreatingJdbcPoolWithoutDatabaseVendor() {
final String poolName = "jdbcPool" + generateRandomString();
final String description = "devtest test connection pool - " + poolName;
clickAndWait("treeForm:tree:resources:JDBC:connectionPoolResources:connectionPoolResources_link", TRIGGER_JDBC_CONNECTION_POOLS);
clickAndWait("propertyForm:poolTable:topActionsGroup1:newButton", TRIGGER_NEW_JDBC_CONNECTION_POOL_STEP_1);
setFieldValue("propertyForm:propertyContentPage:propertySheet:generalPropertySheet:jndiProp:name", poolName);
selectDropdownOption("propertyForm:propertyContentPage:propertySheet:generalPropertySheet:resTypeProp:resType", "javax.sql.ConnectionPoolDataSource");
clickAndWait("propertyForm:propertyContentPage:topButtons:nextButton", TRIGGER_NEW_JDBC_CONNECTION_POOL_STEP_2);
setFieldValue("form2:sheet:generalSheet:descProp:desc", description);
setFieldValue("form2:sheet:generalSheet:dsProp:datasourceField", poolName + "DataSource");
clickAndWait("form2:propertyContentPage:topButtons:finishButton", TRIGGER_JDBC_CONNECTION_POOLS);
assertTrue(isTextPresent(poolName) && isTextPresent(description));
deleteRow("propertyForm:poolTable:topActionsGroup1:button1", "propertyForm:poolTable", poolName);
}
@Test
public void testJdbcResources() {
final String jndiName = "jdbcResource" + generateRandomString();
final String description = "devtest test jdbc resource - " + jndiName;
StandaloneTest standaloneTest = new StandaloneTest();
ClusterTest clusterTest = new ClusterTest();
standaloneTest.deleteAllStandaloneInstances();
clusterTest.deleteAllClusters();
clickAndWait("treeForm:tree:resources:JDBC:jdbcResources:jdbcResources_link", TRIGGER_JDBC_RESOURCES);
clickAndWait("propertyForm:resourcesTable:topActionsGroup1:newButton", TRIGGER_NEW_JDBC_RESOURCE);
setFieldValue("form:propertySheet:propertSectionTextField:nameNew:name", jndiName);
setFieldValue("form:propertySheet:propertSectionTextField:descProp:desc", description);
int count = addTableRow("form:basicTable", "form:basicTable:topActionsGroup1:addSharedTableButton");
setFieldValue("form:basicTable:rowGroup1:0:col2:col1St", "property"+generateRandomString());
setFieldValue("form:basicTable:rowGroup1:0:col3:col1St", "value");
setFieldValue("form:basicTable:rowGroup1:0:col4:col1St", "description");
clickAndWait("form:propertyContentPage:topButtons:newButton", TRIGGER_JDBC_RESOURCES);
assertTrue(isTextPresent(jndiName));
assertTrue(isTextPresent(description));
clickAndWait(getLinkIdByLinkText("propertyForm:resourcesTable", jndiName), TRIGGER_EDIT_JDBC_RESOURCE);
assertTableRowCount("propertyForm:basicTable", count);
clickAndWait("propertyForm:propertyContentPage:topButtons:cancelButton", TRIGGER_JDBC_RESOURCES);
testDisableButton(jndiName,
"propertyForm:resourcesTable",
"propertyForm:resourcesTable:topActionsGroup1:button3",
"propertyForm:propertySheet:propertSectionTextField:statusProp:enabled",
"propertyForm:propertyContentPage:topButtons:cancelButton",
TRIGGER_JDBC_RESOURCES,
TRIGGER_EDIT_JDBC_RESOURCE,
"off");
testEnableButton(jndiName,
"propertyForm:resourcesTable",
"propertyForm:resourcesTable:topActionsGroup1:button2",
"propertyForm:propertySheet:propertSectionTextField:statusProp:enabled",
"propertyForm:propertyContentPage:topButtons:cancelButton",
TRIGGER_JDBC_RESOURCES,
TRIGGER_EDIT_JDBC_RESOURCE,
"on");
deleteRow("propertyForm:resourcesTable:topActionsGroup1:button1", "propertyForm:resourcesTable", jndiName);
}
@Test
public void testJdbcResourcesWithTargets() {
final String jndiName = "jdbcResource" + generateRandomString();
final String instanceName = "standalone" + generateRandomString();
final String description = "devtest test jdbc resource with targets- " + jndiName;
final String enableStatus = "Enabled on 2 of 2 Target(s)";
final String disableStatus = "Enabled on 0 of 2 Target(s)";
StandaloneTest instanceTest = new StandaloneTest();
instanceTest.createStandAloneInstance(instanceName);
clickAndWait("treeForm:tree:resources:JDBC:jdbcResources:jdbcResources_link", TRIGGER_JDBC_RESOURCES);
clickAndWait("propertyForm:resourcesTable:topActionsGroup1:newButton", TRIGGER_NEW_JDBC_RESOURCE);
setFieldValue("form:propertySheet:propertSectionTextField:nameNew:name", jndiName);
setFieldValue("form:propertySheet:propertSectionTextField:descProp:desc", description);
int count = addTableRow("form:basicTable", "form:basicTable:topActionsGroup1:addSharedTableButton");
setFieldValue("form:basicTable:rowGroup1:0:col2:col1St", "property"+generateRandomString());
setFieldValue("form:basicTable:rowGroup1:0:col3:col1St", "value");
setFieldValue("form:basicTable:rowGroup1:0:col4:col1St", "description");
addSelectSelection("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove_available", instanceName);
addSelectSelection("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove_available", "server");
pressButton("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove:commonAddRemove_addButton");
clickAndWait("form:propertyContentPage:topButtons:newButton", TRIGGER_JDBC_RESOURCES);
assertTrue(isTextPresent(jndiName));
assertTrue(isTextPresent(description));
clickAndWait(getLinkIdByLinkText("propertyForm:resourcesTable", jndiName), TRIGGER_EDIT_JDBC_RESOURCE);
assertTableRowCount("propertyForm:basicTable", count);
clickAndWait("propertyForm:propertyContentPage:topButtons:cancelButton", TRIGGER_JDBC_RESOURCES);
testDisableButton(jndiName,
"propertyForm:resourcesTable",
"propertyForm:resourcesTable:topActionsGroup1:button3",
"propertyForm:propertySheet:propertSectionTextField:statusProp2:enabledStr",
"propertyForm:propertyContentPage:topButtons:cancelButton",
TRIGGER_JDBC_RESOURCES,
TRIGGER_EDIT_JDBC_RESOURCE,
disableStatus);
testEnableButton(jndiName,
"propertyForm:resourcesTable",
"propertyForm:resourcesTable:topActionsGroup1:button2",
"propertyForm:propertySheet:propertSectionTextField:statusProp2:enabledStr",
"propertyForm:propertyContentPage:topButtons:cancelButton",
TRIGGER_JDBC_RESOURCES,
TRIGGER_EDIT_JDBC_RESOURCE,
enableStatus);
testManageTargets("treeForm:tree:resources:JDBC:jdbcResources:jdbcResources_link",
"propertyForm:resourcesTable",
"propertyForm:targetTable:topActionsGroup1:button2",
"propertyForm:targetTable:topActionsGroup1:button3",
"propertyForm:propertySheet:propertSectionTextField:statusProp2:enabledStr",
"propertyForm:resEditTabs:general",
"propertyForm:resEditTabs:targetTab",
TRIGGER_JDBC_RESOURCES,
TRIGGER_EDIT_JDBC_RESOURCE,
jndiName,
instanceName);
deleteRow("propertyForm:resourcesTable:topActionsGroup1:button1", "propertyForm:resourcesTable", jndiName);
//Delete the instance
clickAndWait("treeForm:tree:standaloneTreeNode:standaloneTreeNode_link", instanceTest.TRIGGER_INSTANCES_PAGE);
deleteRow("propertyForm:instancesTable:topActionsGroup1:button1", "propertyForm:instancesTable", instanceName);
assertFalse(tableContainsRow("propertyForm:instancesTable", "col0", instanceName));
}
public void createJDBCResource(String jndiName, String description, String target, String targetType) {
if (targetType.equals(MonitoringTest.TARGET_STANDALONE_TYPE)) {
StandaloneTest instanceTest = new StandaloneTest();
instanceTest.createStandAloneInstance(target);
} else if (targetType.equals(MonitoringTest.TARGET_CLUSTER_TYPE)) {
ClusterTest clusterTest = new ClusterTest();
clusterTest.createCluster(target);
}
clickAndWait("treeForm:tree:resources:JDBC:jdbcResources:jdbcResources_link", TRIGGER_JDBC_RESOURCES);
clickAndWait("propertyForm:resourcesTable:topActionsGroup1:newButton", TRIGGER_NEW_JDBC_RESOURCE);
setFieldValue("form:propertySheet:propertSectionTextField:nameNew:name", jndiName);
setFieldValue("form:propertySheet:propertSectionTextField:descProp:desc", description);
if (targetType.equals(MonitoringTest.TARGET_STANDALONE_TYPE)) {
addSelectSelection("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove_available", target);
pressButton("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove:commonAddRemove_addButton");
} else if (targetType.equals(MonitoringTest.TARGET_CLUSTER_TYPE)) {
addSelectSelection("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove_available", target);
pressButton("form:targetSection:targetSectionId:addRemoveProp:commonAddRemove:commonAddRemove_addButton");
}
clickAndWait("form:propertyContentPage:topButtons:newButton", TRIGGER_JDBC_RESOURCES);
assertTrue(isTextPresent(jndiName));
assertTrue(isTextPresent(description));
}
public void deleteJDBCResource(String jndiName, String target, String targetType) {
clickAndWait("treeForm:tree:resources:JDBC:jdbcResources:jdbcResources_link", TRIGGER_JDBC_RESOURCES);
deleteRow("propertyForm:resourcesTable:topActionsGroup1:button1", "propertyForm:resourcesTable", jndiName);
assertFalse(isTextPresent(jndiName));
if (targetType.equals(MonitoringTest.TARGET_STANDALONE_TYPE)) {
//Delete the instance
clickAndWait("treeForm:tree:standaloneTreeNode:standaloneTreeNode_link", StandaloneTest.TRIGGER_INSTANCES_PAGE);
deleteRow("propertyForm:instancesTable:topActionsGroup1:button1", "propertyForm:instancesTable", target);
assertFalse(tableContainsRow("propertyForm:instancesTable", "col1", target));
} else if (targetType.equals(MonitoringTest.TARGET_CLUSTER_TYPE)) {
clickAndWait("treeForm:tree:clusterTreeNode:clusterTreeNode_link", ClusterTest.TRIGGER_CLUSTER_PAGE);
deleteRow("propertyForm:clustersTable:topActionsGroup1:button1", "propertyForm:clustersTable", target);
assertFalse(tableContainsRow("propertyForm:clustersTable", "col1", target));
}
}
}