You are viewing a plain text version of this content. The canonical link for it is here.
Posted to oak-commits@jackrabbit.apache.org by ca...@apache.org on 2018/09/13 10:15:57 UTC

svn commit: r1840797 - /jackrabbit/oak/trunk/oak-it/src/test/java/org/apache/jackrabbit/oak/composite/CompositeNodeStoreClusterObservationTest.java

Author: catholicon
Date: Thu Sep 13 10:15:57 2018
New Revision: 1840797

URL: http://svn.apache.org/viewvc?rev=1840797&view=rev
Log:
OAK-7710: CompositeNodeStore does not dispatch external events to observers

Added another test

Modified:
    jackrabbit/oak/trunk/oak-it/src/test/java/org/apache/jackrabbit/oak/composite/CompositeNodeStoreClusterObservationTest.java

Modified: jackrabbit/oak/trunk/oak-it/src/test/java/org/apache/jackrabbit/oak/composite/CompositeNodeStoreClusterObservationTest.java
URL: http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-it/src/test/java/org/apache/jackrabbit/oak/composite/CompositeNodeStoreClusterObservationTest.java?rev=1840797&r1=1840796&r2=1840797&view=diff
==============================================================================
--- jackrabbit/oak/trunk/oak-it/src/test/java/org/apache/jackrabbit/oak/composite/CompositeNodeStoreClusterObservationTest.java (original)
+++ jackrabbit/oak/trunk/oak-it/src/test/java/org/apache/jackrabbit/oak/composite/CompositeNodeStoreClusterObservationTest.java Thu Sep 13 10:15:57 2018
@@ -92,7 +92,37 @@ public class CompositeNodeStoreClusterOb
         remote.runBackgroundOperations();
         globalStore.runBackgroundOperations();
 
-        assertTrue("Node added event not observed for local change", observer.added.containsKey("/test"));
+        assertTrue("Node added event not observed for remote change", observer.added.containsKey("/test"));
+    }
+
+    @Test
+    public void mixedObservation() throws CommitFailedException {
+        store.addObserver(observer);
+
+        NodeBuilder builder = store.getRoot().builder();
+        builder.child("test").child("test1").setProperty("foo", "bar");
+        merge(store, builder);
+
+        // public local changes
+        globalStore.runBackgroundOperations();
+        remote.runBackgroundOperations();
+
+        builder = remote.getRoot().builder();
+        builder.getChildNode("test").child("test2").setProperty("foo", "bar");
+        merge(remote, builder);
+
+        // read in remote changes
+        remote.runBackgroundOperations();
+        globalStore.runBackgroundOperations();
+
+        builder = store.getRoot().builder();
+        builder.getChildNode("test").child("test3").setProperty("foo", "bar");
+        merge(store, builder);
+
+        assertTrue("Node added event not observed for local change before remote change", observer.added.containsKey("/test"));
+        assertTrue("Node added event not observed for local change before remote change", observer.added.containsKey("/test/test1"));
+        assertTrue("Node added event not observed for remote change", observer.added.containsKey("/test/test2"));
+        assertTrue("Node added event not observed for local change after remote change", observer.added.containsKey("/test/test3"));
     }
 
     private static void merge(NodeStore store, NodeBuilder builder)