package org.infinispan.tx;
import org.infinispan.commands.VisitableCommand;
import org.infinispan.config.Configuration;
import org.infinispan.context.InvocationContext;
import org.infinispan.interceptors.base.CommandInterceptor;
import org.infinispan.interceptors.locking.PessimisticLockingInterceptor;
import org.infinispan.test.MultipleCacheManagersTest;
import org.infinispan.transaction.LockingMode;
import org.testng.annotations.Test;
/**
* @author Mircea Markus <mircea.markus@jboss.com> (C) 2011 Red Hat Inc.
* @since 5.1
*/
@Test (groups = "functional", testName = "tx.ExceptionDuringGetTest")
public class ExceptionDuringGetTest extends MultipleCacheManagersTest {
@Override
protected void createCacheManagers() throws Throwable {
Configuration dcc = getDefaultClusteredConfig(Configuration.CacheMode.DIST_SYNC, true);
dcc.fluent().transaction().lockingMode(LockingMode.PESSIMISTIC);
createCluster(dcc, 2);
waitForClusterToForm();
cache(0).put("k", "v");
assert cache(1).get("k").equals("v");
}
@Test(expectedExceptions = RuntimeException.class, expectedExceptionsMessageRegExp = "Induced!")
public void testExceptionDuringGet() {
advancedCache(0).addInterceptorAfter(new CommandInterceptor() {
@Override
protected Object handleDefault(InvocationContext ctx, VisitableCommand command) throws Throwable {
throw new RuntimeException("Induced!");
}
}, PessimisticLockingInterceptor.class);
cache(0).get("k");
assert false;
}
}