/* * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. * * Copyright (c) 1997-2010 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.admin.amxtest.base; import com.sun.appserv.management.DomainRoot; import com.sun.appserv.management.base.AMX; import com.sun.appserv.management.base.QueryMgr; import com.sun.appserv.management.base.Util; import com.sun.appserv.management.base.XTypes; import com.sun.appserv.management.config.AdminObjectResourceConfig; import com.sun.appserv.management.config.ConnectorResourceConfig; import com.sun.appserv.management.config.CustomResourceConfig; import com.sun.appserv.management.config.JDBCResourceConfig; import com.sun.appserv.management.config.JNDIResourceConfig; import com.sun.appserv.management.config.MailResourceConfig; import com.sun.appserv.management.config.ResourceConfig; import com.sun.appserv.management.util.jmx.JMXUtil; import com.sun.appserv.management.util.misc.CollectionUtil; import com.sun.appserv.management.util.misc.GSetUtil; import org.glassfish.admin.amxtest.AMXTestBase; import org.glassfish.admin.amxtest.Capabilities; import javax.management.ObjectName; import java.util.HashSet; import java.util.Iterator; import java.util.Set; /** */ public final class QueryMgrTest extends AMXTestBase { final QueryMgr mQM; public QueryMgrTest() { mQM = getQueryMgr(); } public static Capabilities getCapabilities() { return getOfflineCapableCapabilities(true); } private <T> void checkSetsEqual( final String msg, final Set<T> set1, final Set<T> set2) { if (!set1.equals(set2)) { final Set<T> conflict = GSetUtil.newNotCommonSet(set1, set2); final String values = CollectionUtil.toString(conflict, "\n"); failure(msg + ", mismatch =\n" + values); } } private void checkAMXWithObjectNames( final String msg, final Set<? extends AMX> set1, final Set<ObjectName> set2) { if (set1.size() != set2.size()) { failure(msg + "set sizes don't match: " + set1.size() + " != " + set2.size()); } final Set<ObjectName> set1ObjectNames = new HashSet<ObjectName>(); for (final AMX item : set1) { final ObjectName objectName = Util.getObjectName(item); if (set1ObjectNames.contains(objectName)) { failure("set1 contains the same proxy twice with ObjectName: " + objectName); } set1ObjectNames.add(objectName); } checkSetsEqual(msg, set1ObjectNames, set2); } static final private Set<String> RESOURCE_TYPES = GSetUtil.newUnmodifiableStringSet( JDBCResourceConfig.J2EE_TYPE, MailResourceConfig.J2EE_TYPE, CustomResourceConfig.J2EE_TYPE, JNDIResourceConfig.J2EE_TYPE, ConnectorResourceConfig.J2EE_TYPE, AdminObjectResourceConfig.J2EE_TYPE); public void testQueryJ2EETypesSet() throws ClassNotFoundException { final long start = now(); final Set<ResourceConfig> resources = mQM.queryJ2EETypesSet(RESOURCE_TYPES); final Set<ObjectName> resourcesObjectNames = mQM.queryJ2EETypesObjectNameSet(RESOURCE_TYPES); assert (resourcesObjectNames.size() >= 1) : "testQueryJ2EETypesSet: no resources found for " + CollectionUtil.toString(RESOURCE_TYPES, ", "); assert (resources.size() >= 1) : "testQueryJ2EETypesSet: no resource ObjectNames found!"; ; checkAMXWithObjectNames( "queryJ2EETypesSet(...) != queryJ2EETypesObjectNameSet(...)", resources, resourcesObjectNames); //println( resourcesObjectNames ); printElapsed("testQueryJ2EETypesSet", start); } public void testQueryJ2EETypePvsON() throws ClassNotFoundException { final long start = now(); final String testType1 = XTypes.DOMAIN_CONFIG; checkAMXWithObjectNames( "queryJ2EETypeSet(XTypes.DOMAIN_CONFIG) != queryJ2EETypeObjectNameSet(XTypes.DOMAIN_CONFIG)", mQM.queryJ2EETypeSet(testType1), mQM.queryJ2EETypeObjectNameSet(testType1)); printElapsed("testQueryJ2EETypePvsON", start); } public void testQueryJ2EENamePvsON() throws ClassNotFoundException { final long start = now(); final String name = getDomainRoot().getName(); checkAMXWithObjectNames( "queryJ2EENameSet() != queryJ2EENameObjectNameSet()", mQM.queryJ2EENameSet(name), mQM.queryJ2EENameObjectNameSet(name)); printElapsed("testQueryJ2EENamePvsON", start); } public void testQueryPatternPvsON() throws ClassNotFoundException { final long start = now(); final String domain = Util.getObjectName(mQM).getDomain(); final ObjectName pat = JMXUtil.newObjectNamePattern(domain, "*"); checkAMXWithObjectNames( "queryPatternSet() != queryPatternObjectNameSet()", mQM.queryPatternSet(pat), mQM.queryPatternObjectNameSet(pat)); checkAMXWithObjectNames( "queryPatternSet() != queryPatternObjectNameSet()", mQM.queryPatternSet(domain, "*"), mQM.queryPatternObjectNameSet(domain, "*")); printElapsed("testQueryPatternPvsON", start); } public void testQueryPropsPvsON() throws ClassNotFoundException { final long start = now(); final String domain = Util.getObjectName(mQM).getDomain(); final String props = Util.makeRequiredProps(XTypes.DOMAIN_ROOT, domain); checkAMXWithObjectNames( "queryPropsSet() != queryPropsObjectNameSet()", mQM.queryPropsSet(props), mQM.queryPropsObjectNameSet(props)); printElapsed("testQueryPropsPvsON", start); } public void testQueryWildPvsON() { final long start = now(); final String[] wildNames = new String[]{"*"}; final String[] wildValues = new String[]{"*"}; checkAMXWithObjectNames( "queryWildSet() != queryWildObjectNameSet()", mQM.queryWildSet(wildNames, wildValues), mQM.queryWildObjectNameSet(wildNames, wildValues)); printElapsed("testQueryWildPvsON", start); } public void testQueryInterfacePvsON() throws ClassNotFoundException { final long start = now(); final Set<AMX> candidates = mQM.queryAllSet(); final Set<ObjectName> candidateObjectNames = Util.toObjectNames(candidates); final String interfaceName = DomainRoot.class.getName(); checkAMXWithObjectNames( "queryInterfaceSet() != queryInterfaceObjectNameSet()", mQM.queryInterfaceSet(interfaceName, candidateObjectNames), mQM.queryInterfaceObjectNameSet(interfaceName, candidateObjectNames)); printElapsed("testQueryInterfacePvsON", start); } public void testQueryAll_AMXMatchesObjectName() throws ClassNotFoundException { final long start = now(); final Set<AMX> allSet = mQM.queryAllSet(); final Set<ObjectName> allObjectNameSet = mQM.queryAllObjectNameSet(); assert (allSet.size() == allObjectNameSet.size()); checkAMXWithObjectNames( "queryAllSet() != queryAllObjectNameSet()", allSet, allObjectNameSet); printElapsed("testQueryAll_AMXMatchesObjectName", start); } public void testGetQueryMgr() { assert (getQueryMgr() != null); } public void testQueryAll() { final long start = now(); final Set result = getQueryMgr().queryAllSet(); assert (result.size() > 1); printElapsed("testQueryAll", start); } public void testGetJ2EETypeObjectNames() throws Exception { final long start = now(); final Set<String> j2eeTypes = getTestUtil().getAvailJ2EETypes(); for (final String j2eeType : j2eeTypes) { final Set<AMX> results = getQueryMgr().queryJ2EETypeSet(j2eeType); assert (results.size() >= 1); } printElapsed("testGetJ2EETypeObjectNames", start); } public void testGetJ2EETypeProxies() throws Exception { final long start = now(); final Set<String> j2eeTypes = getTestUtil().getAvailJ2EETypes(); for (final String j2eeType : j2eeTypes) { final Set<AMX> proxies = getQueryMgr().queryJ2EETypeSet(j2eeType); assert (proxies != null); } printElapsed("testGetJ2EETypeProxies", start); } public void testQueryPatternProxies() throws Exception { final long start = now(); final Set proxies = getQueryMgr().queryPropsSet("*"); assert proxies != null; printElapsed("testQueryPatternProxies", start); } private <T extends AMX> Set<String> getAllInterfaceNames(final Set<T> amxSet) { final Set<String> interfaceNames = new HashSet<String>(); for (final T amx : amxSet) { interfaceNames.add(Util.getExtra(amx).getInterfaceName()); } return (interfaceNames); } /** Final all available interfaces, then for each type of interface, query for all items that have the interface and verify that's the interface they return from getInterfaceName(). */ public void testQueryInterfaceObjectNames() throws Exception { final long start = now(); final QueryMgr queryMgr = getQueryMgr(); final Set<AMX> allAMX = getQueryMgr().queryAllSet(); final Set<ObjectName> allAMXObjectNames = Util.toObjectNames(allAMX); final Set<String> interfaceNames = getAllInterfaceNames(allAMX); for (final String interfaceName : interfaceNames) { final Set amxs = queryMgr.queryInterfaceSet(interfaceName, allAMXObjectNames); final Iterator amxIter = amxs.iterator(); while (amxIter.hasNext()) { final AMX amx = Util.asAMX(amxIter.next()); assert (interfaceName.equals(Util.getExtra(amx).getInterfaceName())); } } printElapsed("testQueryInterfaceObjectNames", start); } }