package org.infinispan.atomic;
import static org.infinispan.test.TestingUtil.withTx;
import static org.testng.AssertJUnit.assertEquals;
import static org.testng.AssertJUnit.assertTrue;
import java.util.concurrent.Callable;
import javax.transaction.TransactionManager;
import org.infinispan.Cache;
import org.infinispan.configuration.cache.CacheMode;
import org.infinispan.configuration.cache.ConfigurationBuilder;
import org.infinispan.persistence.dummy.DummyInMemoryStoreConfigurationBuilder;
import org.infinispan.test.MultipleCacheManagersTest;
import org.testng.annotations.Test;
/**
* Test atomic map operations in a clustered environment where passivation
* has been configured.
*
* @author Galder ZamarreƱo
* @since 5.1
*/
@Test(groups = "functional", testName = "atomic.ClusteredAtomicMapPassivationTest")
public class ClusteredAtomicMapPassivationTest extends MultipleCacheManagersTest {
@Override
protected void createCacheManagers() throws Throwable {
ConfigurationBuilder builder = getDefaultClusteredCacheConfig(
CacheMode.REPL_SYNC, true);
builder.eviction().maxEntries(1024)
.persistence().passivation(true)
.addStore(DummyInMemoryStoreConfigurationBuilder.class);
createClusteredCaches(2, "atomic", builder);
}
public void testEviction() throws Exception {
final Cache<String, Object> cache1 = cache(0, "atomic");
final Cache<String, Object> cache2 = cache(1, "atomic");
TransactionManager tm1 = cache1.getAdvancedCache().getTransactionManager();
withTx(tm1, new Callable<Void>() {
@Override
public Void call() throws Exception {
// Add atomic map in first node
AtomicMap<String, String> map = AtomicMapLookup.getAtomicMap(
cache1, "map");
map.put("key1", "value1");
map.put("key2", "value2");
return null;
}
});
// From second node, passivate the map
cache2.evict("map");
withTx(tm1, new Callable<Void>() {
@Override
public Void call() throws Exception {
// Modify atomic map from first node
AtomicMap<String, String> map = AtomicMapLookup
.getAtomicMap(cache1, "map");
map.put("key1", "new_value1");
assertTrue(map.containsKey("key2"));
assertEquals("value2", map.get("key2"));
return null;
}
});
// Lookup entry from second node and verify it has all the data
AtomicMap<String, String> map = AtomicMapLookup.getAtomicMap(cache2, "map");
assertTrue(map.containsKey("key1"));
assertTrue(map.containsKey("key2"));
assertEquals("new_value1", map.get("key1"));
assertEquals("value2", map.get("key2"));
}
}