package org.infinispan.xsite.statetransfer;
import org.infinispan.configuration.cache.CacheMode;
import org.infinispan.configuration.cache.ConfigurationBuilder;
import org.testng.annotations.Test;
/**
* Tests the cross-site replication with concurrent operations checking for consistency using a distributed synchronous
* cache with two-phases backup.
*
* @author Pedro Ruivo
* @since 7.0
*/
@Test(groups = "xsite", testName = "xsite.statetransfer.DistSyncTwoPhasesTxStateTransferTest")
public class DistSyncTwoPhasesTxStateTransferTest extends BaseStateTransferTest {
public DistSyncTwoPhasesTxStateTransferTest() {
super();
use2Pc = true;
implicitBackupCache = true;
}
@Override
protected ConfigurationBuilder getNycActiveConfig() {
return getDefaultClusteredCacheConfig(CacheMode.DIST_SYNC, true);
}
@Override
protected ConfigurationBuilder getLonActiveConfig() {
return getDefaultClusteredCacheConfig(CacheMode.DIST_SYNC, true);
}
@Test(enabled = false)
@Override
public void testClearOperationBeforeState() throws Exception {
/*
It does not work with the current clear implementation. this is what is happening:
0) assume cache is not empty
1) state transfer and clear happens at the same time
2) clear (PrepareCommand) arrives first than the state
2.1) clear is replayed. the behavior is to iterate over all keys, lock, wrap, and mark them as removed.
however, there is no key in the cache
3) the state arrives. it acquires locks and applies the keys (note that 2.1) didn't acquire any lock)
4) CommitCommand arrives. For all entries wrapped, it is removed. However, nothing was wrapped so nothing gets
removed
https://issues.jboss.org/browse/ISPN-4073
*/
super.testClearOperationBeforeState();
}
}