/* * JBoss, Home of Professional Open Source * Copyright 2010 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.config; import org.infinispan.manager.EmbeddedCacheManager; import org.infinispan.test.AbstractInfinispanTest; import org.infinispan.test.TestingUtil; import org.infinispan.test.fwk.TestCacheManagerFactory; import org.testng.annotations.Test; import java.io.ByteArrayInputStream; import java.io.IOException; import java.io.InputStream; @Test(testName = "config.DifferentCacheModesTest", groups = "unit") public class DifferentCacheModesTest extends AbstractInfinispanTest { public void testCacheModes() throws IOException { EmbeddedCacheManager cm = null; try { String xml = "<infinispan>" + "<global><transport /></global>" + "<default><clustering mode=\"repl\"><sync /></clustering></default>" + "<namedCache name=\"local\"><clustering mode=\"local\" /></namedCache>" + "<namedCache name=\"dist\"><clustering mode=\"dist\"><sync /></clustering></namedCache>" + "<namedCache name=\"distasync\"><clustering mode=\"distribution\"><async /></clustering></namedCache>" + "<namedCache name=\"replicationasync\"><clustering mode=\"replication\"><async /></clustering></namedCache>" + "</infinispan>"; InputStream is = new ByteArrayInputStream(xml.getBytes()); cm = TestCacheManagerFactory.fromStream(is); GlobalConfiguration gc = cm.getGlobalConfiguration(); Configuration defaultCfg = cm.getCache().getConfiguration(); assert gc.getTransportClass() != null; assert defaultCfg.getCacheMode() == Configuration.CacheMode.REPL_SYNC; Configuration cfg = cm.getCache("local").getConfiguration(); assert cfg.getCacheMode() == Configuration.CacheMode.LOCAL; cfg = cm.getCache("dist").getConfiguration(); assert cfg.getCacheMode() == Configuration.CacheMode.DIST_SYNC; cfg = cm.getCache("distasync").getConfiguration(); assert cfg.getCacheMode() == Configuration.CacheMode.DIST_ASYNC; cfg = cm.getCache("replicationasync").getConfiguration(); assert cfg.getCacheMode() == Configuration.CacheMode.REPL_ASYNC; } finally { TestingUtil.killCacheManagers(cm); } } public void testReplicationAndStateTransfer() throws IOException { EmbeddedCacheManager cm = null; try { String xml = "<infinispan>" + "<global><transport /></global>" + "<default><clustering mode=\"repl\"><sync /></clustering></default>" + "<namedCache name=\"explicit-state-disable\">" + "<clustering mode=\"repl\">" + "<sync />" + "<stateRetrieval fetchInMemoryState=\"false\"/>" + "</clustering>" + "</namedCache>" + "<namedCache name=\"explicit-state-enable\">" + "<clustering mode=\"repl\">" + "<sync />" + "<stateRetrieval fetchInMemoryState=\"true\"/>" + "</clustering>" + "</namedCache>" + "<namedCache name=\"explicit-state-enable-async\">" + "<clustering mode=\"repl\">" + "<async />" + "<stateRetrieval fetchInMemoryState=\"true\"/>" + "</clustering>" + "</namedCache>" + "</infinispan>"; InputStream is = new ByteArrayInputStream(xml.getBytes()); cm = TestCacheManagerFactory.fromStream(is); GlobalConfiguration gc = cm.getGlobalConfiguration(); Configuration defaultCfg = cm.getCache().getConfiguration(); assert defaultCfg.getCacheMode() == Configuration.CacheMode.REPL_SYNC; assert defaultCfg.isStateTransferEnabled(); Configuration explicitDisable = cm.getCache("explicit-state-disable").getConfiguration(); assert explicitDisable.getCacheMode() == Configuration.CacheMode.REPL_SYNC; assert !explicitDisable.isStateTransferEnabled(); Configuration explicitEnable = cm.getCache("explicit-state-enable").getConfiguration(); assert explicitEnable.getCacheMode() == Configuration.CacheMode.REPL_SYNC; assert explicitEnable.isStateTransferEnabled(); Configuration explicitEnableAsync = cm.getCache("explicit-state-enable-async").getConfiguration(); assert explicitEnableAsync.getCacheMode() == Configuration.CacheMode.REPL_ASYNC; assert explicitEnableAsync.isStateTransferEnabled(); } finally { TestingUtil.killCacheManagers(cm); } } }