Author: mreutegg
Date: Fri May 22 09:31:19 2020
New Revision: 1878021
URL: http://svn.apache.org/viewvc?rev=1878021&view=rev
Log:
OAK-9088: FlatFileStoreIteratorTest fails on Windows
Release resources when iterator reaches last element
Update test to consume all elements of iterator
Modified:
jackrabbit/oak/trunk/oak-run/src/main/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIterator.java
jackrabbit/oak/trunk/oak-run/src/test/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIteratorTest.java
Modified:
jackrabbit/oak/trunk/oak-run/src/main/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIterator.java
URL:
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-run/src/main/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIterator.java?rev=1878021&r1=1878020&r2=1878021&view=diff
==============================================================================
---
jackrabbit/oak/trunk/oak-run/src/main/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIterator.java
(original)
+++
jackrabbit/oak/trunk/oak-run/src/main/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIterator.java
Fri May 22 09:31:19 2020
@@ -85,6 +85,7 @@ class FlatFileStoreIterator extends Abst
current = computeNextEntry();
if (current == null) {
log.info("Max buffer size in complete traversal is [{}]",
maxBufferSize);
+ buffer.close();
return endOfData();
} else {
return current;
Modified:
jackrabbit/oak/trunk/oak-run/src/test/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIteratorTest.java
URL:
http://svn.apache.org/viewvc/jackrabbit/oak/trunk/oak-run/src/test/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIteratorTest.java?rev=1878021&r1=1878020&r2=1878021&view=diff
==============================================================================
---
jackrabbit/oak/trunk/oak-run/src/test/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIteratorTest.java
(original)
+++
jackrabbit/oak/trunk/oak-run/src/test/java/org/apache/jackrabbit/oak/index/indexer/document/flatfile/FlatFileStoreIteratorTest.java
Fri May 22 09:31:19 2020
@@ -19,11 +19,13 @@
package org.apache.jackrabbit.oak.index.indexer.document.flatfile;
+import java.io.File;
import java.util.Iterator;
import java.util.List;
import java.util.Set;
import com.google.common.collect.ImmutableSet;
+import com.google.common.collect.Iterators;
import com.google.common.collect.Lists;
import org.apache.jackrabbit.oak.index.indexer.document.NodeStateEntry;
import org.apache.jackrabbit.oak.plugins.memory.EmptyNodeState;
@@ -41,15 +43,17 @@ import static org.junit.Assert.fail;
public class FlatFileStoreIteratorTest {
+ private static final File TEST_FOLDER = new File("target", "test");
+
protected FlatFileStoreIterator newInMemoryFlatFileStore(
Iterator<NodeStateEntry> it, Set<String> set, int memMB) {
BlobStore blobStore = null;
- return new FlatFileStoreIterator(blobStore, "target/test", it, set,
memMB);
+ return new FlatFileStoreIterator(blobStore, TEST_FOLDER.getPath(),
it, set, memMB);
}
protected FlatFileStoreIterator newFlatFileStore(Iterator<NodeStateEntry>
it, Set<String> set) {
BlobStore blobStore = null;
- return new FlatFileStoreIterator(blobStore, "target/test", it, set);
+ return new FlatFileStoreIterator(blobStore, TEST_FOLDER.getPath(),
it, set);
}
@Test
@@ -158,6 +162,9 @@ public class FlatFileStoreIteratorTest {
// Don't read whole tree to conclude that "j:c" doesn't exist (reading
/a/b should imply that it doesn't exist)
assertEquals(1, fitr.getBufferSize());
+
+ // read remaining entries to trigger release of resources
+ Iterators.size(fitr);
}
@Test