/* * 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.distribution; import org.infinispan.Cache; import org.infinispan.CacheException; import org.infinispan.config.Configuration; import org.infinispan.manager.EmbeddedCacheManager; import org.infinispan.remoting.transport.Address; import org.infinispan.util.concurrent.IsolationLevel; import org.testng.annotations.Test; import java.io.Externalizable; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; import java.util.ArrayList; import java.util.concurrent.TimeUnit; /** * Test single owner distributed cache configurations. * * @author Galder ZamarreƱo * @since 4.0 */ @Test(groups = "functional", testName = "distribution.SingleOwnerTest") public class SingleOwnerTest extends BaseDistFunctionalTest { @Override protected void createCacheManagers() throws Throwable { cacheName = "dist"; configuration = getDefaultClusteredConfig(sync ? Configuration.CacheMode.DIST_SYNC : Configuration.CacheMode.DIST_ASYNC, tx); if (!testRetVals) { configuration.setUnsafeUnreliableReturnValues(true); // we also need to use repeatable read for tests to work when we dont have reliable return values, since the // tests repeatedly queries changes configuration.setIsolationLevel(IsolationLevel.REPEATABLE_READ); } configuration.setSyncReplTimeout(3, TimeUnit.SECONDS); configuration.setNumOwners(1); configuration.setLockAcquisitionTimeout(45, TimeUnit.SECONDS); caches = createClusteredCaches(2, cacheName, configuration); c1 = caches.get(0); c2 = caches.get(1); cacheAddresses = new ArrayList<Address>(2); for (Cache cache : caches) { EmbeddedCacheManager cacheManager = cache.getCacheManager(); cacheAddresses.add(cacheManager.getAddress()); } waitForClusterToForm(cacheName); } public void testPutOnKeyOwner() { Cache[] caches = getOwners("mykey", 1); assert caches.length == 1; Cache ownerCache = caches[0]; ownerCache.put("mykey", new Object()); } public void testClearOnKeyOwner() { Cache[] caches = getOwners("mykey", 1); assert caches.length == 1; Cache ownerCache = caches[0]; ownerCache.clear(); } public void testRetrieveNonSerializableKeyFromNonOwner() { Cache[] owners = getOwners("yourkey", 1); Cache[] nonOwners = getNonOwners("yourkey", 1); assert owners.length == 1; assert nonOwners.length == 1; Cache ownerCache = owners[0]; Cache nonOwnerCache = nonOwners[0]; ownerCache.put("yourkey", new Object()); try { nonOwnerCache.get("yourkey"); assert false : "Should have failed with a org.infinispan.marshall.NotSerializableException"; } catch (org.infinispan.marshall.NotSerializableException e) { } } public void testErrorWhenRetrievingKeyFromNonOwner() { log.trace("Before test"); Cache[] owners = getOwners("diffkey", 1); Cache[] nonOwners = getNonOwners("diffkey", 1); assert owners.length == 1; assert nonOwners.length == 1; Cache ownerCache = owners[0]; Cache nonOwnerCache = nonOwners[0]; ownerCache.put("diffkey", new Externalizable() { private static final long serialVersionUID = -483939825697574242L; public void writeExternal(ObjectOutput out) throws IOException { throw new UnknownError(); } public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { } }); try { nonOwnerCache.get("diffkey"); assert false : "Should have failed with a CacheException that contains an UnknownError"; } catch (CacheException e) { if (e.getCause() != null) { assert e.getCause() instanceof UnknownError : e.getCause(); } else { throw e; } } } }