/* * JBoss, Home of Professional Open Source * Copyright 2009 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.profiling; import org.infinispan.config.Configuration; import org.infinispan.config.GlobalConfiguration; import org.infinispan.executors.ExecutorFactory; import org.infinispan.manager.EmbeddedCacheManager; import org.infinispan.test.SingleCacheManagerTest; import org.infinispan.test.fwk.TestCacheManagerFactory; import org.infinispan.transaction.lookup.JBossStandaloneJTAManagerLookup; import org.infinispan.util.concurrent.WithinThreadExecutor; import org.testng.annotations.Test; import java.util.Properties; import java.util.concurrent.ExecutorService; import static org.infinispan.config.Configuration.CacheMode.*; @Test(groups = "profiling", enabled = false, testName = "profiling.AbstractProfileTest") public abstract class AbstractProfileTest extends SingleCacheManagerTest { protected static final String LOCAL_CACHE_NAME = "local"; protected static final String REPL_SYNC_CACHE_NAME = "repl_sync"; protected static final String REPL_ASYNC_CACHE_NAME = "repl_async"; protected static final String DIST_SYNC_L1_CACHE_NAME = "dist_sync_l1"; protected static final String DIST_ASYNC_L1_CACHE_NAME = "dist_async_l1"; protected static final String DIST_SYNC_CACHE_NAME = "dist_sync"; protected static final String DIST_ASYNC_CACHE_NAME = "dist_async"; boolean startedInCmdLine = false; String clusterNameOverride = null; protected void initTest() throws Exception { System.out.println("Setting up test params!"); if (startedInCmdLine) cacheManager = createCacheManager(); } private Configuration getBaseCfg() { Configuration cfg = new Configuration(); cfg.setConcurrencyLevel(5000); cfg.setTransactionManagerLookupClass(JBossStandaloneJTAManagerLookup.class.getName()); return cfg; } private Configuration getClusteredCfg(Configuration.CacheMode mode, boolean l1) { Configuration cfg = getBaseCfg(); cfg.setLockAcquisitionTimeout(60000); cfg.setSyncReplTimeout(60000); cfg.setCacheMode(mode); cfg.setFetchInMemoryState(false); if (mode.isDistributed()) { cfg.setL1CacheEnabled(l1); cfg.setL1Lifespan(120000); } return cfg; } protected EmbeddedCacheManager createCacheManager() throws Exception { GlobalConfiguration gc = GlobalConfiguration.getClusteredDefault(); gc.setAsyncTransportExecutorFactoryClass(WTE.class.getName()); cacheManager = TestCacheManagerFactory.createCacheManager(gc); cacheManager.defineConfiguration(LOCAL_CACHE_NAME, getBaseCfg()); cacheManager.defineConfiguration(REPL_SYNC_CACHE_NAME, getClusteredCfg(REPL_SYNC, false)); cacheManager.defineConfiguration(REPL_ASYNC_CACHE_NAME, getClusteredCfg(REPL_ASYNC, false)); cacheManager.defineConfiguration(DIST_SYNC_CACHE_NAME, getClusteredCfg(DIST_SYNC, false)); cacheManager.defineConfiguration(DIST_ASYNC_CACHE_NAME, getClusteredCfg(DIST_ASYNC, false)); cacheManager.defineConfiguration(DIST_SYNC_L1_CACHE_NAME, getClusteredCfg(DIST_SYNC, true)); cacheManager.defineConfiguration(DIST_ASYNC_L1_CACHE_NAME, getClusteredCfg(DIST_ASYNC, true)); return cacheManager; } public static class WTE implements ExecutorFactory { public ExecutorService getExecutor(Properties p) { return new WithinThreadExecutor(); } } }