/* * JBoss, Home of Professional Open Source * Copyright 2011 Red Hat Inc. and/or its affiliates and other * contributors as indicated by the @author tags. All rights reserved. * See the copyright.txt in the distribution for a full listing of * individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.infinispan.jmx; import org.infinispan.config.Configuration; import org.infinispan.config.GlobalConfiguration; import org.infinispan.manager.CacheContainer; import org.infinispan.test.MultipleCacheManagersTest; import org.infinispan.test.fwk.TestCacheManagerFactory; import org.testng.annotations.Test; import javax.management.MBeanServer; import javax.management.ObjectName; import static org.infinispan.test.TestingUtil.*; import static org.testng.AssertJUnit.assertEquals; /** * Clustered cache manager MBean test * * @author Galder ZamarreƱo * @since 4.2 */ @Test(groups = "functional", testName = "jmx.ClusteredCacheManagerMBeanTest") public class ClusteredCacheManagerMBeanTest extends MultipleCacheManagersTest { public static final String JMX_DOMAIN = ClusteredCacheManagerMBeanTest.class.getSimpleName(); public static final String JMX_DOMAIN2 = JMX_DOMAIN + "2"; private ObjectName name1; private ObjectName name2; private MBeanServer server; @Override protected void createCacheManagers() throws Throwable { GlobalConfiguration globalConfiguration = GlobalConfiguration.getClusteredDefault(); globalConfiguration.setExposeGlobalJmxStatistics(true); globalConfiguration.setAllowDuplicateDomains(true); globalConfiguration.setJmxDomain(JMX_DOMAIN); globalConfiguration.setMBeanServerLookup(PerThreadMBeanServerLookup.class.getName()); CacheContainer cacheManager1 = TestCacheManagerFactory.createCacheManagerEnforceJmxDomain(globalConfiguration); cacheManager1.start(); GlobalConfiguration globalConfiguration2 = GlobalConfiguration.getClusteredDefault(); globalConfiguration2.setExposeGlobalJmxStatistics(true); globalConfiguration2.setMBeanServerLookup(PerThreadMBeanServerLookup.class.getName()); globalConfiguration2.setJmxDomain(JMX_DOMAIN); globalConfiguration2.setAllowDuplicateDomains(true); CacheContainer cacheManager2 = TestCacheManagerFactory.createCacheManagerEnforceJmxDomain(globalConfiguration2); cacheManager2.start(); registerCacheManager(cacheManager1, cacheManager2); name1 = getCacheManagerObjectName(JMX_DOMAIN); name2 = getCacheManagerObjectName(JMX_DOMAIN2); server = PerThreadMBeanServerLookup.getThreadMBeanServer(); Configuration config = getDefaultClusteredConfig(Configuration.CacheMode.REPL_SYNC); config.setExposeJmxStatistics(true); defineConfigurationOnAllManagers("mycache", config); manager(0).getCache("mycache"); manager(1).getCache("mycache"); } public void testAddressInformation() throws Exception { String cm1Address = manager(0).getAddress().toString(); String cm2Address = manager(1).getAddress().toString(); assert server.getAttribute(name1, "NodeAddress").equals(cm1Address); assert server.getAttribute(name1, "ClusterMembers").toString().contains(cm1Address); assert !server.getAttribute(name1, "PhysicalAddresses").toString().equals("local"); assert server.getAttribute(name1, "ClusterSize").equals(2); assert server.getAttribute(name2, "NodeAddress").equals(cm2Address); assert server.getAttribute(name2, "ClusterMembers").toString().contains(cm2Address); assert !server.getAttribute(name2, "PhysicalAddresses").toString().equals("local"); assert server.getAttribute(name2, "ClusterSize").equals(2); } public void testJGroupsInformation() throws Exception { ObjectName jchannelName1 = getJGroupsChannelObjectName(JMX_DOMAIN, manager(0).getClusterName()); ObjectName jchannelName2 = getJGroupsChannelObjectName(JMX_DOMAIN2, manager(1).getClusterName()); assertEquals(server.getAttribute(name1, "NodeAddress"), server.getAttribute(jchannelName1, "Address")); assertEquals(server.getAttribute(name2, "NodeAddress"), server.getAttribute(jchannelName2, "Address")); assert (Boolean) server.getAttribute(jchannelName1, "Connected"); assert (Boolean) server.getAttribute(jchannelName2, "Connected"); } }