JBoss Cache SVN: r5139 - in pojo/branches/2.1/src/test/java/org/jboss/cache/pojo: collection and 1 other directory.
by jbosscache-commits@lists.jboss.org
Author: jason.greene(a)jboss.com
Date: 2008-01-15 19:39:45 -0500 (Tue, 15 Jan 2008)
New Revision: 5139
Modified:
pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java
pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTxTest.java
pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java
Log:
Disable tests that fail due to JBCACHE-1165
Modified: pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java
===================================================================
--- pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java 2008-01-15 22:09:29 UTC (rev 5138)
+++ pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java 2008-01-16 00:39:45 UTC (rev 5139)
@@ -30,7 +30,7 @@
* @author Ben Wang
*/
-@Test(groups = {"functional"})
+@Test(groups = {"functional"}, enabled=false)
public class NewReplicatedTest
{
Log log_ = LogFactory.getLog(NewReplicatedTest.class);
Modified: pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTxTest.java
===================================================================
--- pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTxTest.java 2008-01-15 22:09:29 UTC (rev 5138)
+++ pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTxTest.java 2008-01-16 00:39:45 UTC (rev 5139)
@@ -40,7 +40,7 @@
* @author Ben Wang
*/
-@Test(groups = {"functional"})
+@Test(groups = {"functional"}, enabled=false)
public class NewReplicatedTxTest
{
Log log = LogFactory.getLog(NewReplicatedTxTest.class);
Modified: pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java
===================================================================
--- pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java 2008-01-15 22:09:29 UTC (rev 5138)
+++ pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java 2008-01-16 00:39:45 UTC (rev 5139)
@@ -29,7 +29,7 @@
* @author Ben Wang
*/
-@Test(groups = {"functional"})
+@Test(groups = {"functional"}, enabled=false)
public class ReplicatedSyncListTest
{
Log log = LogFactory.getLog(ReplicatedSyncListTest.class);
16 years, 12 months
JBoss Cache SVN: r5138 - in pojo/branches/2.1/src/test/java/org/jboss/cache/pojo: collection and 1 other directory.
by jbosscache-commits@lists.jboss.org
Author: jason.greene(a)jboss.com
Date: 2008-01-15 17:09:29 -0500 (Tue, 15 Jan 2008)
New Revision: 5138
Modified:
pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java
pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java
Log:
Fix invalid cache usage
Modified: pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java
===================================================================
--- pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java 2008-01-15 17:11:39 UTC (rev 5137)
+++ pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/NewReplicatedTest.java 2008-01-15 22:09:29 UTC (rev 5138)
@@ -251,7 +251,7 @@
// restart cache1_
cache1_.stop();
- cache1_.getCache().removeNode(Fqn.fromString("/a"));
+ //cache1_.getCache().removeNode(Fqn.fromString("/a"));
cache1_.start();
// Start from scratch for initial state transfer
Person remote = (Person) cache1_.find("/a");
Modified: pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java
===================================================================
--- pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java 2008-01-15 17:11:39 UTC (rev 5137)
+++ pojo/branches/2.1/src/test/java/org/jboss/cache/pojo/collection/ReplicatedSyncListTest.java 2008-01-15 22:09:29 UTC (rev 5138)
@@ -48,7 +48,7 @@
@AfterMethod(alwaysRun = true)
protected void tearDown() throws Exception
{
- cache1.getCache().removeNode(Fqn.fromString("/"));
+ //cache1.getCache().removeNode(Fqn.fromString("/"));
cache1.stop();
cache2.stop();
}
16 years, 12 months
JBoss Cache SVN: r5137 - in core/tags/2.1.0.CR3: src/main/java/org/jboss/cache and 1 other directory.
by jbosscache-commits@lists.jboss.org
Author: manik.surtani(a)jboss.com
Date: 2008-01-15 12:11:39 -0500 (Tue, 15 Jan 2008)
New Revision: 5137
Modified:
core/tags/2.1.0.CR3/pom.xml
core/tags/2.1.0.CR3/src/main/java/org/jboss/cache/Version.java
Log:
Modified: core/tags/2.1.0.CR3/pom.xml
===================================================================
--- core/tags/2.1.0.CR3/pom.xml 2008-01-15 17:10:07 UTC (rev 5136)
+++ core/tags/2.1.0.CR3/pom.xml 2008-01-15 17:11:39 UTC (rev 5137)
@@ -4,7 +4,7 @@
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<properties>
- <jbosscache-core-version>2.1.0-SNAPSHOT</jbosscache-core-version>
+ <jbosscache-core-version>2.1.0.CR3</jbosscache-core-version>
</properties>
<parent>
<groupId>org.jboss.cache</groupId>
Modified: core/tags/2.1.0.CR3/src/main/java/org/jboss/cache/Version.java
===================================================================
--- core/tags/2.1.0.CR3/src/main/java/org/jboss/cache/Version.java 2008-01-15 17:10:07 UTC (rev 5136)
+++ core/tags/2.1.0.CR3/src/main/java/org/jboss/cache/Version.java 2008-01-15 17:11:39 UTC (rev 5137)
@@ -11,10 +11,10 @@
@Immutable
public class Version
{
- public static final String version = "2.1.0-SNAPSHOT";
+ public static final String version = "2.1.0.CR3";
public static final String codename = "Alegrias";
public static final String cvs = "$Id: Version.java 4592 2007-10-10 16:44:36Z manik.surtani(a)jboss.com $";
- static final byte[] version_id = {'0', '2', '1', '0', 'S'};
+ static final byte[] version_id = {'0', '2', '1', '0', 'C', '3'};
private static final int MAJOR_SHIFT = 11;
private static final int MINOR_SHIFT = 6;
16 years, 12 months
JBoss Cache SVN: r5136 - core/tags.
by jbosscache-commits@lists.jboss.org
Author: manik.surtani(a)jboss.com
Date: 2008-01-15 12:10:07 -0500 (Tue, 15 Jan 2008)
New Revision: 5136
Added:
core/tags/2.1.0.CR3/
Log:
Copied: core/tags/2.1.0.CR3 (from rev 5135, core/trunk)
16 years, 12 months
JBoss Cache SVN: r5135 - core/tags.
by jbosscache-commits@lists.jboss.org
Author: manik.surtani(a)jboss.com
Date: 2008-01-15 12:09:45 -0500 (Tue, 15 Jan 2008)
New Revision: 5135
Removed:
core/tags/2.1.0.CR3/
Log:
16 years, 12 months
JBoss Cache SVN: r5134 - core/trunk/src/test/java/org/jboss/cache/eviction.
by jbosscache-commits@lists.jboss.org
Author: manik.surtani(a)jboss.com
Date: 2008-01-15 06:11:32 -0500 (Tue, 15 Jan 2008)
New Revision: 5134
Modified:
core/trunk/src/test/java/org/jboss/cache/eviction/EvictionConfigurationTest.java
Log:
Fixed broken test
Modified: core/trunk/src/test/java/org/jboss/cache/eviction/EvictionConfigurationTest.java
===================================================================
--- core/trunk/src/test/java/org/jboss/cache/eviction/EvictionConfigurationTest.java 2008-01-15 11:05:23 UTC (rev 5133)
+++ core/trunk/src/test/java/org/jboss/cache/eviction/EvictionConfigurationTest.java 2008-01-15 11:11:32 UTC (rev 5134)
@@ -193,14 +193,14 @@
public void testNoEviction() throws Exception
{
- cache = (CacheSPI<Object, Object>) new DefaultCacheFactory().createCache();
+ cache = (CacheSPI<Object, Object>) new DefaultCacheFactory<Object, Object>().createCache();
regionManager = cache.getRegionManager();
- assertEquals(1, regionManager.getAllRegions(Region.Type.ANY).size());
+ assertEquals(0, regionManager.getAllRegions(Region.Type.ANY).size());
}
private void setupCache(String configurationName)
{
- cache = (CacheSPI<Object, Object>) new DefaultCacheFactory().createCache(configurationName, false);
+ cache = (CacheSPI<Object, Object>) new DefaultCacheFactory<Object, Object>().createCache(configurationName, false);
cache.getConfiguration().setTransactionManagerLookupClass("org.jboss.cache.transaction.DummyTransactionManagerLookup");
cache.getConfiguration().setIsolationLevel(IsolationLevel.SERIALIZABLE);
cache.start();
16 years, 12 months
JBoss Cache SVN: r5133 - in core/trunk/src: main/java/org/jboss/cache/util/reflect and 1 other directories.
by jbosscache-commits@lists.jboss.org
Author: manik.surtani(a)jboss.com
Date: 2008-01-15 06:05:23 -0500 (Tue, 15 Jan 2008)
New Revision: 5133
Removed:
core/trunk/src/main/java/org/jboss/cache/util/reflect/ClasspathScanner.java
core/trunk/src/test/java/org/jboss/cache/util/reflect/
Modified:
core/trunk/src/main/java/org/jboss/cache/factories/ComponentRegistry.java
Log:
hard coded factory registration rather than using a classpath scanner
Modified: core/trunk/src/main/java/org/jboss/cache/factories/ComponentRegistry.java
===================================================================
--- core/trunk/src/main/java/org/jboss/cache/factories/ComponentRegistry.java 2008-01-15 10:40:11 UTC (rev 5132)
+++ core/trunk/src/main/java/org/jboss/cache/factories/ComponentRegistry.java 2008-01-15 11:05:23 UTC (rev 5133)
@@ -16,7 +16,6 @@
import org.jboss.cache.factories.annotations.Stop;
import org.jboss.cache.invocation.RemoteCacheInvocationDelegate;
import org.jboss.cache.util.BeanUtils;
-import org.jboss.cache.util.reflect.ClasspathScanner;
import org.jboss.cache.util.reflect.ReflectionUtil;
import java.lang.annotation.Annotation;
@@ -91,6 +90,28 @@
}
/**
+ * This is hard coded for now, since scanning the classpath for factories annotated with {@link org.jboss.cache.factories.annotations.DefaultFactoryFor}
+ * does not work with all class loaders. This is a temporary solution until a more elegant one can be designed.
+ * <p/>
+ * BE SURE TO ADD ANY NEW FACTORY TYPES ANNOTATED WITH DefaultFactoryFor TO THIS SET!!
+ * <p/>
+ *
+ * @return set of known factory types.
+ */
+ private Set<Class<? extends ComponentFactory>> getHardcodedFactories()
+ {
+ Set<Class<? extends ComponentFactory>> s = new HashSet<Class<? extends ComponentFactory>>();
+ s.add(BuddyManagerFactory.class);
+ s.add(EmptyConstructorFactory.class);
+ s.add(InterceptorChainFactory.class);
+ s.add(LockTableFactory.class);
+ s.add(RuntimeConfigAwareFactory.class);
+ s.add(TransactionManagerFactory.class);
+ return s;
+ }
+
+
+ /**
* Adds a singleton instance to the registry. Note that if an instance of this component already exists in the
* registry it is overwritten. The instance is registered under type <tt>component.getClass()</tt>. If the component
* implements an interface or extends an abstract class, it may make more sense to use {@link #registerComponent(String, Object, Class)}
@@ -518,10 +539,8 @@
{
defaultFactories = new HashMap<Class, Class<? extends ComponentFactory>>();
- ClasspathScanner scanner = new ClasspathScanner();
+ Set<Class<? extends ComponentFactory>> factories = getHardcodedFactories();
- Set<Class<? extends ComponentFactory>> factories = scanner.scan(DefaultFactoryFor.class, ComponentFactory.class);
-
for (Class<? extends ComponentFactory> factory : factories)
{
DefaultFactoryFor dFFAnnotation = factory.getAnnotation(DefaultFactoryFor.class);
Deleted: core/trunk/src/main/java/org/jboss/cache/util/reflect/ClasspathScanner.java
===================================================================
--- core/trunk/src/main/java/org/jboss/cache/util/reflect/ClasspathScanner.java 2008-01-15 10:40:11 UTC (rev 5132)
+++ core/trunk/src/main/java/org/jboss/cache/util/reflect/ClasspathScanner.java 2008-01-15 11:05:23 UTC (rev 5133)
@@ -1,174 +0,0 @@
-package org.jboss.cache.util.reflect;
-
-import org.apache.commons.logging.Log;
-import org.apache.commons.logging.LogFactory;
-import org.jboss.cache.config.ConfigurationException;
-
-import java.io.File;
-import java.io.IOException;
-import java.lang.annotation.Annotation;
-import java.net.MalformedURLException;
-import java.net.URL;
-import java.net.URLClassLoader;
-import java.util.Collections;
-import java.util.Enumeration;
-import java.util.HashSet;
-import java.util.Set;
-import java.util.zip.ZipEntry;
-import java.util.zip.ZipFile;
-
-/**
- * Class for scanning archives and classpaths in the current JBoss Cache classpath for classes annotated with a given annotation. Inspired by a similar class in
- * JBoss SEAM.
- *
- * @author Manik Surtani
- */
-public class ClasspathScanner
-{
- private Log log = LogFactory.getLog(ClasspathScanner.class);
- URLClassLoader classLoader;
-
- /**
- * Constructor with the type of annotation to scan for.
- */
- public ClasspathScanner()
- {
- classLoader = (URLClassLoader) ClasspathScanner.class.getClassLoader();
- }
-
- /**
- * Scans the class path element that contains JBoss Cache for all classes that contain the annotation type this class is
- * initialised with. Note that this only scans CLASSES for the annotation; not methods, etc.
- *
- * @param annotationType the type of annotation to scan for.
- * @param classType the type of class to scan for. Subclasses will be scanned, others will not.
- * @return a set of Classes that contain the specified annotation on the class.
- */
- public <T> Set<Class<? extends T>> scan(Class<? extends Annotation> annotationType, Class<T> classType)
- {
- Set<Class<? extends T>> classes = Collections.emptySet();
-
- try
- {
- // only scan the current ClassPath location that contains this file. Could be a directory or a JAR file.
- URL url = getURLPathFromClassLoader("org/jboss/cache/Cache.class");
- String urlPath = url.getFile();
- if (urlPath.endsWith("/"))
- {
- urlPath = urlPath.substring(0, urlPath.length() - 1);
- }
-
- if (log.isDebugEnabled()) log.debug("scanning: " + urlPath);
- File file = new File(urlPath);
- if (file.isDirectory())
- {
- classes = handleDirectory(file, null, classType, annotationType);
- }
- else
- {
- classes = handleArchive(file, classType, annotationType);
- }
- }
- catch (IOException ioe)
- {
- log.fatal("could not read entries", ioe);
- }
- catch (ClassNotFoundException e)
- {
- log.fatal("Unable to load class", e);
- }
-
- return classes;
- }
-
- URL getURLPathFromClassLoader(String resourceName) throws MalformedURLException
- {
- URL u2 = classLoader.findResource(resourceName);
- String u2String = u2.toString();
-
- boolean isJar = u2String.startsWith("jar:") && (u2String.toLowerCase().contains(".jar!/") || u2String.toLowerCase().contains(".zip!/"));
-
- for (URL u : classLoader.getURLs())
- {
- String originalUrlString = u.toString().replaceAll("\\/\\.\\/", "/");
- String urlString = originalUrlString;
- if (isJar) urlString = "jar:" + urlString + "!/";
- if (u2String.startsWith(urlString)) return new URL(originalUrlString);
- }
-
- throw new ConfigurationException("Unable to find core JBoss Cache classes on classpath!");
- }
-
-
- private <T> Set<Class<? extends T>> handleArchive(File file, Class<T> classType, Class<? extends Annotation> annotationType) throws IOException, ClassNotFoundException
- {
- Set<Class<? extends T>> classesWithAnnotations = new HashSet<Class<? extends T>>();
- ZipFile zip = new ZipFile(file);
- Enumeration<? extends ZipEntry> entries = zip.entries();
- while (entries.hasMoreElements())
- {
- ZipEntry entry = entries.nextElement();
- String name = entry.getName();
- Class<? extends T> c = handleItem(name, classType, annotationType);
- if (c != null) classesWithAnnotations.add(c);
- }
-
- return classesWithAnnotations;
- }
-
- private <T> Set<Class<? extends T>> handleDirectory(File file, String path, Class<T> classType, Class<? extends Annotation> annotationType) throws IOException, ClassNotFoundException
- {
- Set<Class<? extends T>> classesWithAnnotations = new HashSet<Class<? extends T>>();
- for (File child : file.listFiles())
- {
- String newPath = path == null ? child.getName() : path + '/' + child.getName();
- if (child.isDirectory())
- {
- classesWithAnnotations.addAll(handleDirectory(child, newPath, classType, annotationType));
- }
- else
- {
- Class<? extends T> c = handleItem(newPath, classType, annotationType);
- if (c != null)
- {
- classesWithAnnotations.add(c);
- }
- }
- }
-
- return classesWithAnnotations;
- }
-
- private <T> Class<? extends T> handleItem(String name, Class<T> classType, Class<? extends Annotation> annotationType) throws IOException, ClassNotFoundException
- {
- if (!name.endsWith(".class")) return null;
-
- Class<? extends T> c = getClassFile(filenameToClassname(name), classType);
- if (c != null && hasAnnotation(c, annotationType))
- {
- return c;
- }
- else
- {
- return null;
- }
- }
-
- private <T> Class<? extends T> getClassFile(String name, Class<T> classType) throws IOException, ClassNotFoundException
- {
- Class c = classLoader.loadClass(name);
- if (c != null && classType.isAssignableFrom(c)) return c;
- else return null;
- }
-
- private boolean hasAnnotation(Class clazz, Class<? extends Annotation> annotationType)
- {
- return (clazz.isAnnotationPresent(annotationType));
- }
-
- private static String filenameToClassname(String filename)
- {
- return filename.substring(0, filename.lastIndexOf(".class")).replace('/', '.').replace('\\', '.');
- }
-
-}
16 years, 12 months
JBoss Cache SVN: r5132 - in core/trunk/src: main/java/org/jboss/cache/invocation and 1 other directories.
by jbosscache-commits@lists.jboss.org
Author: manik.surtani(a)jboss.com
Date: 2008-01-15 05:40:11 -0500 (Tue, 15 Jan 2008)
New Revision: 5132
Modified:
core/trunk/src/main/java/org/jboss/cache/config/Option.java
core/trunk/src/main/java/org/jboss/cache/invocation/NodeInvocationDelegate.java
core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java
Log:
JBCACHE-1263 Node.addChild() local mode suppression
Modified: core/trunk/src/main/java/org/jboss/cache/config/Option.java
===================================================================
--- core/trunk/src/main/java/org/jboss/cache/config/Option.java 2008-01-15 05:17:56 UTC (rev 5131)
+++ core/trunk/src/main/java/org/jboss/cache/config/Option.java 2008-01-15 10:40:11 UTC (rev 5132)
@@ -238,21 +238,29 @@
public String toString()
{
return "Option{" +
- "failSilently=" + failSilently +
- ", cacheModeLocal=" + cacheModeLocal +
- ", dataVersion=" + dataVersion +
- ", suppressLocking=" + suppressLocking +
- ", lockAcquisitionTimeout=" + lockAcquisitionTimeout +
- ", forceDataGravitation=" + forceDataGravitation +
- ", skipDataGravitation=" + skipDataGravitation +
- ", forceAsynchronous=" + forceAsynchronous +
- ", forceSynchronous=" + forceSynchronous +
- '}';
+ "failSilently=" + failSilently +
+ ", cacheModeLocal=" + cacheModeLocal +
+ ", dataVersion=" + dataVersion +
+ ", suppressLocking=" + suppressLocking +
+ ", lockAcquisitionTimeout=" + lockAcquisitionTimeout +
+ ", forceDataGravitation=" + forceDataGravitation +
+ ", skipDataGravitation=" + skipDataGravitation +
+ ", forceAsynchronous=" + forceAsynchronous +
+ ", forceSynchronous=" + forceSynchronous +
+ '}';
}
- public Option clone() throws CloneNotSupportedException
+ public Option clone()
{
- return (Option) super.clone();
+ try
+ {
+ return (Option) super.clone();
+ }
+ catch (CloneNotSupportedException e)
+ {
+ // should never happen!
+ throw new RuntimeException(e);
+ }
}
Modified: core/trunk/src/main/java/org/jboss/cache/invocation/NodeInvocationDelegate.java
===================================================================
--- core/trunk/src/main/java/org/jboss/cache/invocation/NodeInvocationDelegate.java 2008-01-15 05:17:56 UTC (rev 5131)
+++ core/trunk/src/main/java/org/jboss/cache/invocation/NodeInvocationDelegate.java 2008-01-15 10:40:11 UTC (rev 5132)
@@ -6,6 +6,7 @@
import org.jboss.cache.NodeNotValidException;
import org.jboss.cache.NodeSPI;
import org.jboss.cache.UnversionedNode;
+import org.jboss.cache.config.Option;
import org.jboss.cache.factories.annotations.Inject;
import org.jboss.cache.lock.NodeLock;
import org.jboss.cache.optimistic.DataVersion;
@@ -273,10 +274,16 @@
// TODO: Revisit. Is this really threadsafe? See comment in putIfAbsent() - same solution should be applied here too.
assertValid();
Fqn nf = new Fqn(getFqn(), f);
+ Option o1 = spi.getInvocationContext().getOptionOverrides().clone();
Node<K, V> child = getChild(f);
+
if (child == null)
{
+ Option o2 = o1.clone();
+ spi.getInvocationContext().setOptionOverrides(o1);
spi.put(nf, null);
+
+ spi.getInvocationContext().setOptionOverrides(o2);
child = getChild(f);
}
return child;
Modified: core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java
===================================================================
--- core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java 2008-01-15 05:17:56 UTC (rev 5131)
+++ core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java 2008-01-15 10:40:11 UTC (rev 5132)
@@ -12,9 +12,7 @@
import org.jboss.cache.Fqn;
import org.jboss.cache.Node;
import org.jboss.cache.config.Configuration;
-import static org.testng.AssertJUnit.assertEquals;
-import static org.testng.AssertJUnit.assertNull;
-import static org.testng.AssertJUnit.assertTrue;
+import static org.testng.AssertJUnit.*;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
@@ -188,8 +186,9 @@
}
// now cache2
- Node node2 = cache2.getRoot().getChild(fqn);
cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ Node node2 = cache2.getRoot().addChild(fqn);
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
node2.put(key, "value2");
delay();
assertEquals("value2", cache2.get(fqn, key));
@@ -291,7 +290,8 @@
}
// now cache2
- Node node2 = cache2.getRoot().getChild(fqn);
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ Node node2 = cache2.getRoot().addChild(fqn);
map.put(key, "value2");
cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
node2.putAll(map);
16 years, 12 months
JBoss Cache SVN: r5131 - in core/trunk/src/main/java/org/jboss/cache: buddyreplication and 1 other directory.
by jbosscache-commits@lists.jboss.org
Author: bstansberry(a)jboss.com
Date: 2008-01-15 00:17:56 -0500 (Tue, 15 Jan 2008)
New Revision: 5131
Modified:
core/trunk/src/main/java/org/jboss/cache/RegionManager.java
core/trunk/src/main/java/org/jboss/cache/buddyreplication/BuddyManager.java
Log:
[JBCACHE-1266] Use Cache.put(Fqn, null) as workaround for Node.addChild(Fqn)
Modified: core/trunk/src/main/java/org/jboss/cache/RegionManager.java
===================================================================
--- core/trunk/src/main/java/org/jboss/cache/RegionManager.java 2008-01-15 03:51:56 UTC (rev 5130)
+++ core/trunk/src/main/java/org/jboss/cache/RegionManager.java 2008-01-15 05:17:56 UTC (rev 5131)
@@ -433,7 +433,11 @@
// need to obtain all necessary locks.
// needs to be a LOCAL call!
cache.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
- subtreeRoot = cache.getRoot().addChild(buddyRoot);
+ // FIXME -- restore the next line and remove the 2 following
+ // when JBCACHE-1265 is fixed
+ //subtreeRoot = cache.getRoot().addChild(buddyRoot);
+ cache.put(buddyRoot, null);
+ subtreeRoot = cache.getRoot().getChild(buddyRoot);
cache.getInvocationContext().getOptionOverrides().setCacheModeLocal(false);
}
cache.fetchPartialState(sources, fqn, subtreeRoot.getFqn());
Modified: core/trunk/src/main/java/org/jboss/cache/buddyreplication/BuddyManager.java
===================================================================
--- core/trunk/src/main/java/org/jboss/cache/buddyreplication/BuddyManager.java 2008-01-15 03:51:56 UTC (rev 5130)
+++ core/trunk/src/main/java/org/jboss/cache/buddyreplication/BuddyManager.java 2008-01-15 05:17:56 UTC (rev 5131)
@@ -538,7 +538,10 @@
o = cache.getInvocationContext().getOptionOverrides();
o.setCacheModeLocal(true);
o.setSkipCacheStatusCheck(true);
- root.addChild(new Fqn<String>(BUDDY_BACKUP_SUBTREE, newGroup.getGroupName()));
+ // FIXME -- restore the next line and remove the following one
+ // when JBCACHE-1265 is fixed
+// root.addChild(new Fqn<String>(BUDDY_BACKUP_SUBTREE, newGroup.getGroupName()));
+ cache.put(new Fqn<String>(BUDDY_BACKUP_SUBTREE, newGroup.getGroupName()), null);
}
else
{
16 years, 12 months
JBoss Cache SVN: r5130 - core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal.
by jbosscache-commits@lists.jboss.org
Author: bstansberry(a)jboss.com
Date: 2008-01-14 22:51:56 -0500 (Mon, 14 Jan 2008)
New Revision: 5130
Modified:
core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java
Log:
[JBCACHE-1265] Setting cacheModeLocal=true ineffective for addChild(Fqn) call
Duplicate the other tests using the Node API.
Modified: core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java
===================================================================
--- core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java 2008-01-15 00:19:02 UTC (rev 5129)
+++ core/trunk/src/test/java/org/jboss/cache/options/cachemodelocal/CacheModeLocalTestBase.java 2008-01-15 03:51:56 UTC (rev 5130)
@@ -10,9 +10,11 @@
import org.jboss.cache.CacheSPI;
import org.jboss.cache.DefaultCacheFactory;
import org.jboss.cache.Fqn;
+import org.jboss.cache.Node;
import org.jboss.cache.config.Configuration;
import static org.testng.AssertJUnit.assertEquals;
import static org.testng.AssertJUnit.assertNull;
+import static org.testng.AssertJUnit.assertTrue;
import org.testng.annotations.AfterMethod;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.Test;
@@ -156,6 +158,57 @@
}
}
+ public void testPutKeyValueViaNodeAPI() throws Exception
+ {
+ Node node1 = cache1.getRoot().addChild(fqn);
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node1.put(key, "value");
+ delay();
+ // cache1 should still have this
+ assertEquals("value", cache1.get(fqn, key));
+
+ // cache 2 should not
+ assertNull("Should be null", cache2.get(fqn, key));
+
+ // now try again with passing the default options
+ cache1.getInvocationContext().getOptionOverrides().reset();
+ node1.put(key, "value");
+ delay();
+ // cache1 should still have this
+ assertEquals("value", cache1.get(fqn, key));
+
+ // cache 2 should as well
+ if (!isInvalidation)
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertNull("should be invalidated", cache2.get(fqn, key));
+ }
+
+ // now cache2
+ Node node2 = cache2.getRoot().getChild(fqn);
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node2.put(key, "value2");
+ delay();
+ assertEquals("value2", cache2.get(fqn, key));
+ assertEquals("value", cache1.get(fqn, key));
+
+ cache2.getInvocationContext().getOptionOverrides().reset();
+ node2.put(key, "value2");
+ delay();
+ assertEquals("value2", cache2.get(fqn, key));
+ if (!isInvalidation)
+ {
+ assertEquals("value2", cache1.get(fqn, key));
+ }
+ else
+ {
+ assertNull("should be invalidated", cache1.get(fqn, key));
+ }
+ }
+
public void testPutData() throws Exception
{
Map<String, String> map = new HashMap<String, String>();
@@ -207,6 +260,59 @@
}
}
+ public void testPutDataViaNodeAPI() throws Exception
+ {
+ Map<String, String> map = new HashMap<String, String>();
+ map.put(key, "value");
+
+ Node node1 = cache1.getRoot().addChild(fqn);
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node1.putAll(map);
+ delay();
+ // cache1 should still have this
+ assertEquals("value", cache1.get(fqn, key));
+ // cache 2 should not
+ assertNull("Should be null", cache2.get(fqn, key));
+
+ // now try again with passing the default options
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(false);
+ node1.putAll(map);
+ delay();
+ // cache1 should still have this
+ assertEquals("value", cache1.get(fqn, key));
+ // cache 2 should as well
+ if (!isInvalidation)
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertNull("should be invalidated", cache2.get(fqn, key));
+ }
+
+ // now cache2
+ Node node2 = cache2.getRoot().getChild(fqn);
+ map.put(key, "value2");
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node2.putAll(map);
+ delay();
+ assertEquals("value2", cache2.get(fqn, key));
+ assertEquals("value", cache1.get(fqn, key));
+
+ cache2.getInvocationContext().getOptionOverrides().reset();
+ node2.put(key, "value2");
+ delay();
+ assertEquals("value2", cache2.get(fqn, key));
+ if (!isInvalidation)
+ {
+ assertEquals("value2", cache1.get(fqn, key));
+ }
+ else
+ {
+ assertNull("should be invalidated", cache1.get(fqn, key));
+ }
+ }
+
public void testRemoveNode() throws Exception
{
// put some stuff in the cache first
@@ -263,6 +369,62 @@
assertNull("should be null", cache2.get(fqn, key));
}
+ public void testRemoveNodeViaNodeAPI() throws Exception
+ {
+ // put some stuff in the cache first
+ // make sure we cleanup thread local vars.
+ cache1.getInvocationContext().setOptionOverrides(null);
+ cache1.put(fqn, key, "value");
+ delay();
+ assertEquals("value", cache1.get(fqn, key));
+ if (isInvalidation)
+ {
+ assertNull("Should be null", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ cache1.getRoot().removeChild(fqn);
+ delay();
+
+ // should be removed in cache1
+ assertNull("should be null", cache1.get(fqn, key));
+ // Not in cache2
+ if (isInvalidation)
+ {
+ assertNull("Should be null", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+
+ // replace cache entries
+ cache1.put(fqn, key, "value");
+ delay();
+ assertEquals("value", cache1.get(fqn, key));
+ if (isInvalidation)
+ {
+ assertNull("Should be null", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+
+ // now try again with passing the default options
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(false);
+ cache1.getRoot().removeChild(fqn);
+ delay();
+
+ // both should be null
+ assertNull("should be null", cache1.get(fqn, key));
+ assertNull("should be null", cache2.get(fqn, key));
+ }
+
public void testRemoveKey() throws Exception
{
// put some stuff in the cache first
@@ -318,6 +480,62 @@
assertNull("should be null", cache2.get(fqn, key));
}
+ public void testRemoveKeyViaNodeAPI() throws Exception
+ {
+ // put some stuff in the cache first
+ Node node1 = cache1.getRoot().addChild(fqn);
+ cache1.getInvocationContext().setOptionOverrides(null);
+ node1.put(key, "value");
+ delay();
+ assertEquals("value", cache1.get(fqn, key));
+ if (isInvalidation)
+ {
+ assertNull("Should be null", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node1.remove(key);
+ delay();
+
+ // should be removed in cache1
+ assertNull("should be null", cache1.get(fqn, key));
+ // Not in cache2
+ if (isInvalidation)
+ {
+ assertNull("Should be null", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+
+ // replace cache entries
+ node1.put(key, "value");
+ delay();
+ assertEquals("value", cache1.get(fqn, key));
+ if (isInvalidation)
+ {
+ assertNull("Should be null", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+
+ // now try again with passing the default options
+ cache1.getInvocationContext().getOptionOverrides().reset();
+ node1.remove(key);
+ delay();
+
+ // both should be null
+ assertNull("should be null", cache1.get(fqn, key));
+ assertNull("should be null", cache2.get(fqn, key));
+ }
+
public void testTransactionalBehaviour() throws Exception
{
TransactionManager mgr = cache1.getTransactionManager();
@@ -401,6 +619,120 @@
}
+ public void testTransactionalBehaviourViaNodeAPI() throws Exception
+ {
+ Node node1 = cache1.getRoot().addChild(fqn);
+ TransactionManager mgr = cache1.getTransactionManager();
+ mgr.begin();
+ cache1.getInvocationContext().getOptionOverrides().reset();
+ node1.put(key, "value1");
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node1.put(key, "value2");
+ mgr.commit();
+ delay();
+ // cache1 should still have this
+ assertEquals("value2", cache1.get(fqn, key));
+
+ if (!isInvalidation)
+ {
+ assertEquals("value1", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertNull(cache2.get(fqn, key));
+ }
+
+ // now try again with passing the default options
+ mgr.begin();
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node1.put(key, "value3");
+ cache1.getInvocationContext().getOptionOverrides().reset();
+ node1.put(key, "value");
+ mgr.commit();
+ delay();
+ // cache1 should still have this
+ assertEquals("value", cache1.get(fqn, key));
+
+ // cache 2 should as well
+ if (!isInvalidation)
+ {
+ assertEquals("value", cache2.get(fqn, key));
+ }
+ else
+ {
+ assertNull("should be invalidated", cache2.get(fqn, key));
+ }
+
+ // now cache2
+ Node node2 = cache2.getRoot().addChild(fqn);
+ mgr = cache2.getTransactionManager();
+ mgr.begin();
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(false);
+ node2.put(key, "value3");
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node2.put(key, "value2");
+ mgr.commit();
+ delay();
+
+ assertEquals("value2", cache2.get(fqn, key));
+
+ if (!isInvalidation)
+ {
+ assertEquals("value3", cache1.get(fqn, key));
+ }
+ else
+ {
+ assertNull(cache1.get(fqn, key));
+ }
+
+ mgr.begin();
+ cache2.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ node2.put(key, "value2");
+ cache2.getInvocationContext().getOptionOverrides().reset();
+ node2.put(key, "value2");
+ mgr.commit();
+ delay();
+ assertEquals("value2", cache2.get(fqn, key));
+ if (!isInvalidation)
+ {
+ assertEquals("value2", cache1.get(fqn, key));
+ }
+ else
+ {
+ assertNull("should be invalidated", cache1.get(fqn, key));
+ }
+
+ }
+
+ public void testAddChild() throws Exception
+ {
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(true);
+ cache1.getRoot().addChild(fqn);
+ delay();
+ // cache1 should still have this
+ assertTrue(cache1.getRoot().hasChild(fqn));
+ // cache 2 should not
+ Node node2 = cache2.getRoot().getChild(fqn);
+ assertTrue("Should be null", node2 == null || (isInvalidation && !node2.isValid()));
+
+ // now try again with passing the default options
+ cache1.getRoot().removeChild(fqn);
+ cache1.getInvocationContext().getOptionOverrides().setCacheModeLocal(false);
+ cache1.getRoot().addChild(fqn);
+ delay();
+ // cache1 should still have this
+ assertTrue(cache1.getRoot().hasChild(fqn));
+ // cache 2 should as well
+ if (!isInvalidation)
+ {
+ assertTrue(cache2.getRoot().hasChild(fqn));
+ }
+ else
+ {
+ assertTrue("Should be null", node2 == null || !node2.isValid());
+ }
+ }
+
protected abstract void delay();
}
\ No newline at end of file
17 years