package org.infinispan.tx;
import org.infinispan.configuration.cache.CacheMode;
import org.infinispan.configuration.cache.ConfigurationBuilder;
import org.infinispan.test.MultipleCacheManagersTest;
import org.infinispan.test.TestingUtil;
import org.testng.annotations.Test;
/**
* @author Mircea Markus
* @since 5.1
*/
@Test(groups = "functional", testName = "tx.TransactionCleanupTest")
public class TransactionCleanupTest extends MultipleCacheManagersTest {
@Override
protected void createCacheManagers() throws Throwable {
ConfigurationBuilder dcc = getConfiguration();
createCluster(dcc, 2);
waitForClusterToForm();
}
protected ConfigurationBuilder getConfiguration() {
return getDefaultClusteredCacheConfig(CacheMode.REPL_SYNC, true);
}
public void transactionCleanupTest1() throws Throwable {
runtTest(1, false);
}
public void transactionCleanupTest2() throws Throwable {
runtTest(0, false);
}
public void transactionCleanupTest3() throws Throwable {
runtTest(1, true);
}
public void transactionCleanupTest4() throws Throwable {
runtTest(0, true);
}
private void runtTest(int initiatorIndex, boolean rollback) throws Throwable{
tm(initiatorIndex).begin();
cache(initiatorIndex).put("k", "v");
if (rollback) {
tm(initiatorIndex).rollback();
} else {
tm(initiatorIndex).commit();
}
assertNotLocked("k");
eventually(() -> (TestingUtil.getTransactionTable(cache(0)).getRemoteTxCount() == 0) &&
(TestingUtil.getTransactionTable(cache(0)).getLocalTxCount() == 0) &&
(TestingUtil.getTransactionTable(cache(1)).getRemoteTxCount() == 0) &&
(TestingUtil.getTransactionTable(cache(1)).getLocalTxCount() == 0));
}
}