fix test bug: use an FSDirectory when there are too many docs

This commit is contained in:
Mike McCandless 2016-06-19 06:03:29 -04:00
parent 2d96fe17d6
commit 4fae4184fd
1 changed files with 17 additions and 2 deletions

View File

@ -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());