package org.infinispan.tx;
import org.infinispan.config.Configuration;
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.TransactionReleaseWithAsync2ndPhaseTest")
public class TransactionCleanupWithAsync2ndPhaseTest extends MultipleCacheManagersTest {
@Override
protected void createCacheManagers() throws Throwable {
final Configuration dcc = getConfiguration();
createCluster(dcc, 2);
waitForClusterToForm();
}
protected Configuration getConfiguration() {
final Configuration dcc = getDefaultClusteredConfig(Configuration.CacheMode.REPL_SYNC, true);
dcc.fluent().transaction().syncCommitPhase(false).syncRollbackPhase(true);
return dcc;
}
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(new Condition() {
@Override
public boolean isSatisfied() throws Exception {
return (TestingUtil.getTransactionTable(cache(0)).getRemoteTxCount() == 0) &&
(TestingUtil.getTransactionTable(cache(0)).getLocalTxCount() == 0) &&
(TestingUtil.getTransactionTable(cache(1)).getRemoteTxCount() == 0) &&
(TestingUtil.getTransactionTable(cache(1)).getLocalTxCount() == 0);
}
});
}
}