/*
* JBoss, Home of Professional Open Source
* Copyright 2009 Red Hat Inc. and/or its affiliates and other
* contributors as indicated by the @author tags. All rights reserved.
* See the copyright.txt in the distribution for a full listing of
* individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.infinispan.tx;
import org.infinispan.Cache;
import org.infinispan.config.Configuration;
import org.infinispan.config.GlobalConfiguration;
import org.infinispan.manager.EmbeddedCacheManager;
import org.infinispan.test.AbstractInfinispanTest;
import org.infinispan.test.TestingUtil;
import org.infinispan.test.fwk.TestCacheManagerFactory;
import org.testng.annotations.AfterTest;
import org.testng.annotations.BeforeTest;
import org.testng.annotations.Test;
import javax.transaction.TransactionManager;
import java.util.ArrayList;
import java.util.List;
@Test(groups = "functional", testName = "tx.OnePhaseXATest", description = "See ISPN-156 for details.")
public class OnePhaseXATest extends AbstractInfinispanTest {
private List<Cache> caches;
private List<EmbeddedCacheManager> cacheContainers;
public static final int CACHES_NUM = 2;
public void testMultipleCaches() throws Exception {
//add something to cache
int i = 0;
for (Cache c : caches) {
TransactionManager tm = TestingUtil.getTransactionManager(c);
tm.begin();
c.put("key" + i, "value");
tm.commit();
i++;
}
//check if caches contain these same keys
i = 0;
for (Cache c : caches) {
assert "value".equals(c.get("key0")) : "Failed getting value for key0 on cache " + i;
assert "value".equals(c.get("key1")) : "Failed getting value for key1 on cache " + i;
i++;
}
}
@BeforeTest
public void setUp() throws Exception {
caches = new ArrayList<Cache>();
cacheContainers = new ArrayList<EmbeddedCacheManager>();
for (int i = 0; i < CACHES_NUM; i++) caches.add(getCache());
}
@AfterTest
public void tearDown() {
if (caches != null) TestingUtil.killCacheManagers(cacheContainers);
}
private Cache getCache() {
GlobalConfiguration gc = GlobalConfiguration.getClusteredDefault();
Configuration c = new Configuration();
c.setInvocationBatchingEnabled(true);
c.setCacheMode(Configuration.CacheMode.REPL_SYNC);
c.setSyncReplTimeout(30000);
c.setLockAcquisitionTimeout(60000);
c.setUseLockStriping(false);
c.setSyncCommitPhase(true);
EmbeddedCacheManager container = TestCacheManagerFactory.createCacheManager(gc, c);
cacheContainers.add(container);
return container.getCache("TestCache");
}
}