Author: mreutegg
Date: Tue Apr 9 15:21:04 2019
New Revision: 1857212
URL: http://svn.apache.org/viewvc?rev=1857212&view=rev
Log:
OAK-8207: Read-only DocumentNodeStore tries to create root document
Modified:
jackrabbit/oak/trunk/oak-store-document/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
jackrabbit/oak/trunk/oak-store-document/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
Modified:
jackrabbit/oak/trunk/oak-store-document/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
URL:
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-store-document/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java?rev=1857212&r1=1857211&r2=1857212&view=diff
==============================================================================
---
jackrabbit/oak/trunk/oak-store-document/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
(original)
+++
jackrabbit/oak/trunk/oak-store-document/src/main/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStore.java
Tue Apr 9 15:21:04 2019
@@ -614,6 +614,11 @@ public final class DocumentNodeStore
// check if root node exists
NodeDocument rootDoc = store.find(NODES, Utils.getIdFromPath("/"));
if (rootDoc == null) {
+ if (readOnlyMode) {
+ throw new DocumentStoreException("Unable to initialized a " +
+ "read-only DocumentNodeStore. The DocumentStore nodes
" +
+ "collection does not have a root document.");
+ }
// root node is missing: repository is not initialized
Revision commitRev = newRevision();
RevisionVector head = new RevisionVector(commitRev);
Modified:
jackrabbit/oak/trunk/oak-store-document/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
URL:
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-store-document/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java?rev=1857212&r1=1857211&r2=1857212&view=diff
==============================================================================
---
jackrabbit/oak/trunk/oak-store-document/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
(original)
+++
jackrabbit/oak/trunk/oak-store-document/src/test/java/org/apache/jackrabbit/oak/plugins/document/DocumentNodeStoreTest.java
Tue Apr 9 15:21:04 2019
@@ -3855,6 +3855,19 @@ public class DocumentNodeStoreTest {
assertFalse(info.isActive());
}
+ @Test
+ public void readOnlyOnEmptyDocumentStore() {
+ DocumentStore store = new MemoryDocumentStore();
+ try {
+ builderProvider.newBuilder().setDocumentStore(store)
+ .setReadOnlyMode().build();
+ fail("must fail with DocumentStoreException");
+ } catch (Exception e) {
+ // must not hit last line of defence (ReadOnlyDocumentStoreWrapper)
+ assertFalse(Throwables.getRootCause(e) instanceof
UnsupportedOperationException);
+ }
+ }
+
private void getChildNodeCountTest(int numChildren,
Iterable<Long> maxValues,
Iterable<Long> expectedValues)