From 4fae4184fdda1aee17248f75453061627fe8901d Mon Sep 17 00:00:00 2001 From: Mike McCandless Date: Sun, 19 Jun 2016 06:03:29 -0400 Subject: [PATCH] fix test bug: use an FSDirectory when there are too many docs --- .../apache/lucene/search/TestBoolean2.java | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java b/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java index 2cd3a37a1a9..8123addab84 100644 --- a/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java +++ b/lucene/core/src/test/org/apache/lucene/search/TestBoolean2.java @@ -33,6 +33,7 @@ import org.apache.lucene.index.Term; import org.apache.lucene.search.similarities.ClassicSimilarity; import org.apache.lucene.search.similarities.Similarity; import org.apache.lucene.store.Directory; +import org.apache.lucene.store.IOContext; import org.apache.lucene.store.MockDirectoryWrapper; import org.apache.lucene.util.LuceneTestCase; import org.apache.lucene.util.TestUtil; @@ -68,8 +69,13 @@ public class TestBoolean2 extends LuceneTestCase { // in some runs, test immediate adjacency of matches - in others, force a full bucket gap betwen docs NUM_FILLER_DOCS = random().nextBoolean() ? 0 : BooleanScorer.SIZE; PRE_FILLER_DOCS = TestUtil.nextInt(random(), 0, (NUM_FILLER_DOCS / 2)); + + if (NUM_FILLER_DOCS * PRE_FILLER_DOCS > 100000) { + directory = newFSDirectory(createTempDir()); + } else { + directory = newDirectory(); + } - directory = newDirectory(); RandomIndexWriter writer= new RandomIndexWriter(random(), directory, newIndexWriterConfig(new MockAnalyzer(random())).setMergePolicy(newLogMergePolicy())); Document doc = new Document(); @@ -92,7 +98,16 @@ public class TestBoolean2 extends LuceneTestCase { searcher.setSimilarity(new ClassicSimilarity()); // make a copy of our index using a single segment - singleSegmentDirectory = new MockDirectoryWrapper(random(), TestUtil.ramCopyOf(directory)); + if (NUM_FILLER_DOCS * PRE_FILLER_DOCS > 100000) { + singleSegmentDirectory = newFSDirectory(createTempDir()); + } else { + singleSegmentDirectory = newDirectory(); + } + + for (String fileName : directory.listAll()) { + singleSegmentDirectory.copyFrom(directory, fileName, fileName, IOContext.DEFAULT); + } + IndexWriterConfig iwc = newIndexWriterConfig(new MockAnalyzer(random())); // we need docID order to be preserved: iwc.setMergePolicy(newLogMergePolicy());