/*
* 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.configuration;
import static org.infinispan.test.TestingUtil.withCacheManager;
import static org.infinispan.transaction.TransactionMode.NON_TRANSACTIONAL;
import static org.testng.Assert.assertEquals;
import java.net.URL;
import javax.xml.XMLConstants;
import javax.xml.transform.Source;
import javax.xml.transform.stream.StreamSource;
import javax.xml.validation.SchemaFactory;
import org.infinispan.Cache;
import org.infinispan.config.ConfigurationException;
import org.infinispan.configuration.cache.CacheMode;
import org.infinispan.configuration.cache.Configuration;
import org.infinispan.configuration.cache.ConfigurationBuilder;
import org.infinispan.configuration.cache.LegacyConfigurationAdaptor;
import org.infinispan.configuration.cache.LockingConfigurationBuilder;
import org.infinispan.configuration.global.GlobalConfigurationBuilder;
import org.infinispan.eviction.EvictionStrategy;
import org.infinispan.manager.DefaultCacheManager;
import org.infinispan.test.CacheManagerCallable;
import org.infinispan.test.fwk.TestCacheManagerFactory;
import org.infinispan.test.fwk.TransportFlags;
import org.infinispan.transaction.lookup.DummyTransactionManagerLookup;
import org.infinispan.util.FileLookup;
import org.infinispan.util.FileLookupFactory;
import org.infinispan.util.concurrent.IsolationLevel;
import org.testng.Assert;
import org.testng.annotations.Test;
@Test(groups = "functional", testName = "configuration.ConfigurationUnitTest")
public class ConfigurationUnitTest {
@Test
public void testBuild() {
// Simple test to ensure we can actually build a config
ConfigurationBuilder cb = new ConfigurationBuilder();
cb.build();
}
@Test
public void testCreateCache() throws Exception {
withCacheManager(new CacheManagerCallable(
new DefaultCacheManager(new ConfigurationBuilder().build())));
}
@Test
public void testAdapt() {
// Simple test to ensure we can actually adapt a config to the old config
ConfigurationBuilder cb = new ConfigurationBuilder();
LegacyConfigurationAdaptor.adapt(cb.build());
}
@Test
public void testEvictionMaxEntries() {
Configuration configuration = new ConfigurationBuilder()
.eviction().maxEntries(20)
.build();
org.infinispan.config.Configuration legacy = LegacyConfigurationAdaptor.adapt(configuration);
Assert.assertEquals(legacy.getEvictionMaxEntries(), 20);
}
@Test
public void testDistSyncAutoCommit() {
Configuration configuration = new ConfigurationBuilder()
.clustering().cacheMode(CacheMode.DIST_SYNC)
.transaction().autoCommit(true)
.build();
org.infinispan.config.Configuration legacy = LegacyConfigurationAdaptor.adapt(configuration);
Assert.assertTrue(legacy.isTransactionAutoCommit());
Assert.assertEquals(legacy.getCacheMode().name(), CacheMode.DIST_SYNC.name());
}
@Test
public void testDummyTMGetCache() throws Exception {
ConfigurationBuilder cb = new ConfigurationBuilder();
cb.transaction().use1PcForAutoCommitTransactions(true)
.transactionManagerLookup(new DummyTransactionManagerLookup());
withCacheManager(new CacheManagerCallable(new DefaultCacheManager(cb.build())) {
@Override
public void call() throws Exception {
cm.getCache();
}
});
}
@Test
public void testGetCache() throws Exception {
withCacheManager(new CacheManagerCallable(
new DefaultCacheManager(new ConfigurationBuilder().build())) {
@Override
public void call() throws Exception {
cm.getCache();
}
});
}
@Test
public void testDefineNamedCache() throws Exception {
withCacheManager(new CacheManagerCallable(
new DefaultCacheManager(new ConfigurationBuilder().build())) {
@Override
public void call() throws Exception {
cm.defineConfiguration("foo", new ConfigurationBuilder().build());
}
});
}
@Test
public void testGetAndPut() throws Exception {
withCacheManager(new CacheManagerCallable(
new DefaultCacheManager(new ConfigurationBuilder().build())) {
@Override
public void call() throws Exception {
Cache<String, String> cache = cm.getCache();
cache.put("Foo", "2");
cache.put("Bar", "4");
Assert.assertEquals(cache.get("Foo"), "2");
Assert.assertEquals(cache.get("Bar"), "4");
}
});
}
@Test
public void testReplAsyncWithQueue() {
Configuration configuration = new ConfigurationBuilder()
.clustering().cacheMode(CacheMode.REPL_ASYNC)
.async().useReplQueue(true).replQueueInterval(1222)
.build();
org.infinispan.config.Configuration legacy = LegacyConfigurationAdaptor.adapt(configuration);
}
@Test(expectedExceptions = IllegalStateException.class)
public void testInvocationBatchingAndNonTransactional() throws Exception {
Configuration c = new ConfigurationBuilder()
.transaction()
.transactionMode(NON_TRANSACTIONAL)
.invocationBatching()
.enable()
.build();
withCacheManager(new CacheManagerCallable(new DefaultCacheManager(c)));
}
@Test
public void testConsistentHash() {
Configuration config = LegacyConfigurationAdaptor.adapt(new org.infinispan.config.Configuration());
Assert.assertNull(config.clustering().hash().consistentHash());
}
@Test
public void testDisableL1() throws Exception {
withCacheManager(new CacheManagerCallable(
TestCacheManagerFactory.createClusteredCacheManager(
new ConfigurationBuilder(), new TransportFlags())) {
@Override
public void call() throws Exception {
ConfigurationBuilder cb = new ConfigurationBuilder();
cb.clustering().cacheMode(CacheMode.DIST_SYNC).l1().disable().disableOnRehash();
cm.defineConfiguration("testConfigCache", cb.build());
Cache<Object, Object> cache = cm.getCache("testConfigCache");
assert !cache.getCacheConfiguration().clustering().l1().enabled();
assert !cache.getCacheConfiguration().clustering().l1().onRehash();
}
});
}
@Test
public void testClearCacheLoaders() {
Configuration c = new ConfigurationBuilder()
.loaders()
.addCacheLoader()
.loaders()
.clearCacheLoaders()
.build();
assertEquals(c.loaders().cacheLoaders().size(), 0);
}
@Test(expectedExceptions = ConfigurationException.class)
public void testClusterNameNull() {
GlobalConfigurationBuilder gc = new GlobalConfigurationBuilder();
gc.transport().clusterName(null).build();
}
@Test
public void testSchema() throws Exception {
FileLookup lookup = FileLookupFactory.newInstance();
URL schemaFile = lookup.lookupFileLocation("schema/infinispan-config-5.2.xsd", Thread.currentThread().getContextClassLoader());
Source xmlFile = new StreamSource(lookup.lookupFile("configs/all.xml", Thread.currentThread().getContextClassLoader()));
SchemaFactory.newInstance(XMLConstants.W3C_XML_SCHEMA_NS_URI).newSchema(schemaFile).newValidator().validate(xmlFile);
}
public void testEvictionWithoutStrategy() throws Exception {
Configuration c = new ConfigurationBuilder()
.eviction().maxEntries(76767)
.build();
withCacheManager(new CacheManagerCallable(new DefaultCacheManager(c)) {
@Override
public void call() throws Exception {
Configuration cfg = cm.getCache().getCacheConfiguration();
assert cfg.eviction().maxEntries() == 76767;
assert cfg.eviction().strategy() != EvictionStrategy.NONE;
}
});
}
@Test(expectedExceptions = IllegalArgumentException.class)
public void testNumOwners() {
ConfigurationBuilder cb = new ConfigurationBuilder();
cb.clustering().cacheMode(CacheMode.DIST_SYNC);
cb.clustering().hash().numOwners(5);
Configuration c = cb.build();
Assert.assertEquals(5, c.clustering().hash().numOwners());
// negative test
cb.clustering().hash().numOwners(0);
}
@Test(expectedExceptions = IllegalArgumentException.class)
public void numVirtualNodes() {
ConfigurationBuilder cb = new ConfigurationBuilder();
cb.clustering().cacheMode(CacheMode.DIST_SYNC);
cb.clustering().hash().numVirtualNodes(5);
Configuration c = cb.build();
Assert.assertEquals(5, c.clustering().hash().numVirtualNodes());
// negative test
cb.clustering().hash().numVirtualNodes(0);
}
public void testEnableVersioning() {
ConfigurationBuilder builder = new ConfigurationBuilder();
builder.versioning().enable();
org.infinispan.config.Configuration adapt =
LegacyConfigurationAdaptor.adapt(builder.build());
assert adapt.isEnableVersioning();
}
public void testNoneIsolationLevel() throws Exception {
ConfigurationBuilder builder = new ConfigurationBuilder();
builder.locking().isolationLevel(IsolationLevel.NONE);
withCacheManager(new CacheManagerCallable(
TestCacheManagerFactory.createCacheManager(builder)) {
@Override
public void call() throws Exception {
Configuration cfg = cm.getCache().getCacheConfiguration();
assertEquals(IsolationLevel.NONE, cfg.locking().isolationLevel());
}
});
}
public void testNoneIsolationLevelInCluster() throws Exception {
ConfigurationBuilder builder = new ConfigurationBuilder();
builder.locking().isolationLevel(IsolationLevel.NONE)
.clustering().cacheMode(CacheMode.REPL_SYNC).build();
withCacheManager(new CacheManagerCallable(
TestCacheManagerFactory.createClusteredCacheManager(builder)) {
@Override
public void call() throws Exception {
Configuration cfg = cm.getCache().getCacheConfiguration();
assertEquals(IsolationLevel.READ_COMMITTED,
cfg.locking().isolationLevel());
}
});
}
}