mirror of https://github.com/apache/lucene.git
LUCENE-5039: Refactor IndexWriter#testPoint() to use InfoStream instead
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1490533 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
3ff9c73184
commit
1f2c01754f
|
@ -112,7 +112,7 @@ class DocumentsWriterPerThread {
|
||||||
|
|
||||||
// Only called by asserts
|
// Only called by asserts
|
||||||
public boolean testPoint(String name) {
|
public boolean testPoint(String name) {
|
||||||
return docWriter.writer.testPoint(name);
|
return docWriter.testPoint(name);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void clear() {
|
public void clear() {
|
||||||
|
@ -232,6 +232,13 @@ class DocumentsWriterPerThread {
|
||||||
aborting = true;
|
aborting = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
final boolean testPoint(String message) {
|
||||||
|
if (infoStream.isEnabled("TP")) {
|
||||||
|
infoStream.message("TP", message);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
boolean checkAndResetHasAborted() {
|
boolean checkAndResetHasAborted() {
|
||||||
final boolean retval = hasAborted;
|
final boolean retval = hasAborted;
|
||||||
hasAborted = false;
|
hasAborted = false;
|
||||||
|
@ -239,7 +246,7 @@ class DocumentsWriterPerThread {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void updateDocument(IndexDocument doc, Analyzer analyzer, Term delTerm) throws IOException {
|
public void updateDocument(IndexDocument doc, Analyzer analyzer, Term delTerm) throws IOException {
|
||||||
assert writer.testPoint("DocumentsWriterPerThread addDocument start");
|
assert testPoint("DocumentsWriterPerThread addDocument start");
|
||||||
assert deleteQueue != null;
|
assert deleteQueue != null;
|
||||||
docState.doc = doc;
|
docState.doc = doc;
|
||||||
docState.analyzer = analyzer;
|
docState.analyzer = analyzer;
|
||||||
|
@ -292,7 +299,7 @@ class DocumentsWriterPerThread {
|
||||||
}
|
}
|
||||||
|
|
||||||
public int updateDocuments(Iterable<? extends IndexDocument> docs, Analyzer analyzer, Term delTerm) throws IOException {
|
public int updateDocuments(Iterable<? extends IndexDocument> docs, Analyzer analyzer, Term delTerm) throws IOException {
|
||||||
assert writer.testPoint("DocumentsWriterPerThread addDocuments start");
|
assert testPoint("DocumentsWriterPerThread addDocuments start");
|
||||||
assert deleteQueue != null;
|
assert deleteQueue != null;
|
||||||
docState.analyzer = analyzer;
|
docState.analyzer = analyzer;
|
||||||
if (segmentInfo == null) {
|
if (segmentInfo == null) {
|
||||||
|
|
|
@ -4162,7 +4162,10 @@ public class IndexWriter implements Closeable, TwoPhaseCommit {
|
||||||
// startCommitMergeDeletes
|
// startCommitMergeDeletes
|
||||||
// startMergeInit
|
// startMergeInit
|
||||||
// DocumentsWriter.ThreadState.init start
|
// DocumentsWriter.ThreadState.init start
|
||||||
boolean testPoint(String name) {
|
private final boolean testPoint(String message) {
|
||||||
|
if (infoStream.isEnabled("TP")) {
|
||||||
|
infoStream.message("TP", message);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -114,7 +114,7 @@ final class StoredFieldsProcessor extends StoredFieldsConsumer {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
void finishDocument() throws IOException {
|
void finishDocument() throws IOException {
|
||||||
assert docWriter.writer.testPoint("StoredFieldsWriter.finishDocument start");
|
assert docWriter.testPoint("StoredFieldsWriter.finishDocument start");
|
||||||
|
|
||||||
initFieldsWriter(IOContext.DEFAULT);
|
initFieldsWriter(IOContext.DEFAULT);
|
||||||
fill(docState.docID);
|
fill(docState.docID);
|
||||||
|
@ -129,7 +129,7 @@ final class StoredFieldsProcessor extends StoredFieldsConsumer {
|
||||||
}
|
}
|
||||||
|
|
||||||
reset();
|
reset();
|
||||||
assert docWriter.writer.testPoint("StoredFieldsWriter.finishDocument end");
|
assert docWriter.testPoint("StoredFieldsWriter.finishDocument end");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -94,7 +94,7 @@ final class TermVectorsConsumer extends TermsHashConsumer {
|
||||||
@Override
|
@Override
|
||||||
void finishDocument(TermsHash termsHash) throws IOException {
|
void finishDocument(TermsHash termsHash) throws IOException {
|
||||||
|
|
||||||
assert docWriter.writer.testPoint("TermVectorsTermsWriter.finishDocument start");
|
assert docWriter.testPoint("TermVectorsTermsWriter.finishDocument start");
|
||||||
|
|
||||||
if (!hasVectors) {
|
if (!hasVectors) {
|
||||||
return;
|
return;
|
||||||
|
@ -117,7 +117,7 @@ final class TermVectorsConsumer extends TermsHashConsumer {
|
||||||
|
|
||||||
termsHash.reset();
|
termsHash.reset();
|
||||||
reset();
|
reset();
|
||||||
assert docWriter.writer.testPoint("TermVectorsTermsWriter.finishDocument end");
|
assert docWriter.testPoint("TermVectorsTermsWriter.finishDocument end");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -25,18 +25,7 @@ import org.apache.lucene.store.*;
|
||||||
import org.apache.lucene.util.*;
|
import org.apache.lucene.util.*;
|
||||||
|
|
||||||
public class TestAtomicUpdate extends LuceneTestCase {
|
public class TestAtomicUpdate extends LuceneTestCase {
|
||||||
private static final class MockIndexWriter extends IndexWriter {
|
|
||||||
public MockIndexWriter(Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
boolean testPoint(String name) {
|
|
||||||
if (LuceneTestCase.random().nextInt(4) == 2)
|
|
||||||
Thread.yield();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static abstract class TimedThread extends Thread {
|
private static abstract class TimedThread extends Thread {
|
||||||
volatile boolean failed;
|
volatile boolean failed;
|
||||||
|
@ -124,7 +113,7 @@ public class TestAtomicUpdate extends LuceneTestCase {
|
||||||
TEST_VERSION_CURRENT, new MockAnalyzer(random()))
|
TEST_VERSION_CURRENT, new MockAnalyzer(random()))
|
||||||
.setMaxBufferedDocs(7);
|
.setMaxBufferedDocs(7);
|
||||||
((TieredMergePolicy) conf.getMergePolicy()).setMaxMergeAtOnce(3);
|
((TieredMergePolicy) conf.getMergePolicy()).setMaxMergeAtOnce(3);
|
||||||
IndexWriter writer = new MockIndexWriter(directory, conf);
|
IndexWriter writer = RandomIndexWriter.mockIndexWriter(directory, conf, random());
|
||||||
|
|
||||||
// Establish a base index of 100 docs:
|
// Establish a base index of 100 docs:
|
||||||
for(int i=0;i<100;i++) {
|
for(int i=0;i<100;i++) {
|
||||||
|
|
|
@ -210,15 +210,10 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
|
|
||||||
ThreadLocal<Thread> doFail = new ThreadLocal<Thread>();
|
ThreadLocal<Thread> doFail = new ThreadLocal<Thread>();
|
||||||
|
|
||||||
private class MockIndexWriter extends IndexWriter {
|
private class TestPoint1 implements RandomIndexWriter.TestPoint {
|
||||||
Random r = new Random(random().nextLong());
|
Random r = new Random(random().nextLong());
|
||||||
|
|
||||||
public MockIndexWriter(Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean testPoint(String name) {
|
public void apply(String name) {
|
||||||
if (doFail.get() != null && !name.equals("startDoFlush") && r.nextInt(40) == 17) {
|
if (doFail.get() != null && !name.equals("startDoFlush") && r.nextInt(40) == 17) {
|
||||||
if (VERBOSE) {
|
if (VERBOSE) {
|
||||||
System.out.println(Thread.currentThread().getName() + ": NOW FAIL: " + name);
|
System.out.println(Thread.currentThread().getName() + ": NOW FAIL: " + name);
|
||||||
|
@ -226,7 +221,6 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
throw new RuntimeException(Thread.currentThread().getName() + ": intentionally failing at " + name);
|
throw new RuntimeException(Thread.currentThread().getName() + ": intentionally failing at " + name);
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -238,8 +232,9 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
|
|
||||||
MockAnalyzer analyzer = new MockAnalyzer(random());
|
MockAnalyzer analyzer = new MockAnalyzer(random());
|
||||||
analyzer.setEnableChecks(false); // disable workflow checking as we forcefully close() in exceptional cases.
|
analyzer.setEnableChecks(false); // disable workflow checking as we forcefully close() in exceptional cases.
|
||||||
MockIndexWriter writer = new MockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, analyzer)
|
|
||||||
.setRAMBufferSizeMB(0.1).setMergeScheduler(new ConcurrentMergeScheduler()));
|
IndexWriter writer = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, analyzer)
|
||||||
|
.setRAMBufferSizeMB(0.1).setMergeScheduler(new ConcurrentMergeScheduler()), new TestPoint1());
|
||||||
((ConcurrentMergeScheduler) writer.getConfig().getMergeScheduler()).setSuppressExceptions();
|
((ConcurrentMergeScheduler) writer.getConfig().getMergeScheduler()).setSuppressExceptions();
|
||||||
//writer.setMaxBufferedDocs(10);
|
//writer.setMaxBufferedDocs(10);
|
||||||
if (VERBOSE) {
|
if (VERBOSE) {
|
||||||
|
@ -281,8 +276,8 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
Directory dir = newDirectory();
|
Directory dir = newDirectory();
|
||||||
MockAnalyzer analyzer = new MockAnalyzer(random());
|
MockAnalyzer analyzer = new MockAnalyzer(random());
|
||||||
analyzer.setEnableChecks(false); // disable workflow checking as we forcefully close() in exceptional cases.
|
analyzer.setEnableChecks(false); // disable workflow checking as we forcefully close() in exceptional cases.
|
||||||
MockIndexWriter writer = new MockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, analyzer)
|
IndexWriter writer = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, analyzer)
|
||||||
.setRAMBufferSizeMB(0.2).setMergeScheduler(new ConcurrentMergeScheduler()));
|
.setRAMBufferSizeMB(0.2).setMergeScheduler(new ConcurrentMergeScheduler()), new TestPoint1());
|
||||||
((ConcurrentMergeScheduler) writer.getConfig().getMergeScheduler()).setSuppressExceptions();
|
((ConcurrentMergeScheduler) writer.getConfig().getMergeScheduler()).setSuppressExceptions();
|
||||||
//writer.setMaxBufferedDocs(10);
|
//writer.setMaxBufferedDocs(10);
|
||||||
writer.commit();
|
writer.commit();
|
||||||
|
@ -324,19 +319,13 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// LUCENE-1198
|
// LUCENE-1198
|
||||||
private static final class MockIndexWriter2 extends IndexWriter {
|
private static final class TestPoint2 implements RandomIndexWriter.TestPoint {
|
||||||
|
|
||||||
public MockIndexWriter2(Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean doFail;
|
boolean doFail;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean testPoint(String name) {
|
public void apply(String name) {
|
||||||
if (doFail && name.equals("DocumentsWriterPerThread addDocument start"))
|
if (doFail && name.equals("DocumentsWriterPerThread addDocument start"))
|
||||||
throw new RuntimeException("intentionally failing");
|
throw new RuntimeException("intentionally failing");
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -367,11 +356,12 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
|
|
||||||
public void testExceptionDocumentsWriterInit() throws IOException {
|
public void testExceptionDocumentsWriterInit() throws IOException {
|
||||||
Directory dir = newDirectory();
|
Directory dir = newDirectory();
|
||||||
MockIndexWriter2 w = new MockIndexWriter2(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer(random())));
|
TestPoint2 testPoint = new TestPoint2();
|
||||||
|
IndexWriter w = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer(random())), testPoint);
|
||||||
Document doc = new Document();
|
Document doc = new Document();
|
||||||
doc.add(newTextField("field", "a field", Field.Store.YES));
|
doc.add(newTextField("field", "a field", Field.Store.YES));
|
||||||
w.addDocument(doc);
|
w.addDocument(doc);
|
||||||
w.doFail = true;
|
testPoint.doFail = true;
|
||||||
try {
|
try {
|
||||||
w.addDocument(doc);
|
w.addDocument(doc);
|
||||||
fail("did not hit exception");
|
fail("did not hit exception");
|
||||||
|
@ -385,7 +375,7 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
// LUCENE-1208
|
// LUCENE-1208
|
||||||
public void testExceptionJustBeforeFlush() throws IOException {
|
public void testExceptionJustBeforeFlush() throws IOException {
|
||||||
Directory dir = newDirectory();
|
Directory dir = newDirectory();
|
||||||
MockIndexWriter w = new MockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer(random())).setMaxBufferedDocs(2));
|
IndexWriter w = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer(random())).setMaxBufferedDocs(2), new TestPoint1());
|
||||||
Document doc = new Document();
|
Document doc = new Document();
|
||||||
doc.add(newTextField("field", "a field", Field.Store.YES));
|
doc.add(newTextField("field", "a field", Field.Store.YES));
|
||||||
w.addDocument(doc);
|
w.addDocument(doc);
|
||||||
|
@ -412,22 +402,15 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static final class MockIndexWriter3 extends IndexWriter {
|
private static final class TestPoint3 implements RandomIndexWriter.TestPoint {
|
||||||
|
|
||||||
public MockIndexWriter3(Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean doFail;
|
boolean doFail;
|
||||||
boolean failed;
|
boolean failed;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean testPoint(String name) {
|
public void apply(String name) {
|
||||||
if (doFail && name.equals("startMergeInit")) {
|
if (doFail && name.equals("startMergeInit")) {
|
||||||
failed = true;
|
failed = true;
|
||||||
throw new RuntimeException("intentionally failing");
|
throw new RuntimeException("intentionally failing");
|
||||||
}
|
}
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -441,8 +424,9 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
cms.setSuppressExceptions();
|
cms.setSuppressExceptions();
|
||||||
conf.setMergeScheduler(cms);
|
conf.setMergeScheduler(cms);
|
||||||
((LogMergePolicy) conf.getMergePolicy()).setMergeFactor(2);
|
((LogMergePolicy) conf.getMergePolicy()).setMergeFactor(2);
|
||||||
MockIndexWriter3 w = new MockIndexWriter3(dir, conf);
|
TestPoint3 testPoint = new TestPoint3();
|
||||||
w.doFail = true;
|
IndexWriter w = RandomIndexWriter.mockIndexWriter(dir, conf, testPoint);
|
||||||
|
testPoint.doFail = true;
|
||||||
Document doc = new Document();
|
Document doc = new Document();
|
||||||
doc.add(newTextField("field", "a field", Field.Store.YES));
|
doc.add(newTextField("field", "a field", Field.Store.YES));
|
||||||
for(int i=0;i<10;i++)
|
for(int i=0;i<10;i++)
|
||||||
|
@ -453,7 +437,7 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
((ConcurrentMergeScheduler) w.getConfig().getMergeScheduler()).sync();
|
((ConcurrentMergeScheduler) w.getConfig().getMergeScheduler()).sync();
|
||||||
assertTrue(w.failed);
|
assertTrue(testPoint.failed);
|
||||||
w.close();
|
w.close();
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
@ -1014,29 +998,26 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
// LUCENE-1347
|
// LUCENE-1347
|
||||||
private static final class MockIndexWriter4 extends IndexWriter {
|
private static final class TestPoint4 implements RandomIndexWriter.TestPoint {
|
||||||
|
|
||||||
public MockIndexWriter4(Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
}
|
|
||||||
|
|
||||||
boolean doFail;
|
boolean doFail;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean testPoint(String name) {
|
public void apply(String name) {
|
||||||
if (doFail && name.equals("rollback before checkpoint"))
|
if (doFail && name.equals("rollback before checkpoint"))
|
||||||
throw new RuntimeException("intentionally failing");
|
throw new RuntimeException("intentionally failing");
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// LUCENE-1347
|
// LUCENE-1347
|
||||||
public void testRollbackExceptionHang() throws Throwable {
|
public void testRollbackExceptionHang() throws Throwable {
|
||||||
Directory dir = newDirectory();
|
Directory dir = newDirectory();
|
||||||
MockIndexWriter4 w = new MockIndexWriter4(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer(random())));
|
TestPoint4 testPoint = new TestPoint4();
|
||||||
|
IndexWriter w = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig( TEST_VERSION_CURRENT, new MockAnalyzer(random())), testPoint);
|
||||||
|
|
||||||
|
|
||||||
addDoc(w);
|
addDoc(w);
|
||||||
w.doFail = true;
|
testPoint.doFail = true;
|
||||||
try {
|
try {
|
||||||
w.rollback();
|
w.rollback();
|
||||||
fail("did not hit intentional RuntimeException");
|
fail("did not hit intentional RuntimeException");
|
||||||
|
@ -1044,7 +1025,7 @@ public class TestIndexWriterExceptions extends LuceneTestCase {
|
||||||
// expected
|
// expected
|
||||||
}
|
}
|
||||||
|
|
||||||
w.doFail = false;
|
testPoint.doFail = false;
|
||||||
w.rollback();
|
w.rollback();
|
||||||
dir.close();
|
dir.close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -47,21 +47,16 @@ public class TestStressIndexing2 extends LuceneTestCase {
|
||||||
static int maxBufferedDocs=3;
|
static int maxBufferedDocs=3;
|
||||||
static int seed=0;
|
static int seed=0;
|
||||||
|
|
||||||
public class MockIndexWriter extends IndexWriter {
|
public final class YieldTestPoint implements RandomIndexWriter.TestPoint {
|
||||||
|
|
||||||
public MockIndexWriter(Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean testPoint(String name) {
|
public void apply(String name) {
|
||||||
// if (name.equals("startCommit")) {
|
// if (name.equals("startCommit")) {
|
||||||
if (random().nextInt(4) == 2)
|
if (random().nextInt(4) == 2)
|
||||||
Thread.yield();
|
Thread.yield();
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//
|
||||||
public void testRandomIWReader() throws Throwable {
|
public void testRandomIWReader() throws Throwable {
|
||||||
Directory dir = newDirectory();
|
Directory dir = newDirectory();
|
||||||
|
|
||||||
|
@ -151,9 +146,9 @@ public class TestStressIndexing2 extends LuceneTestCase {
|
||||||
|
|
||||||
public DocsAndWriter indexRandomIWReader(int nThreads, int iterations, int range, Directory dir) throws IOException, InterruptedException {
|
public DocsAndWriter indexRandomIWReader(int nThreads, int iterations, int range, Directory dir) throws IOException, InterruptedException {
|
||||||
Map<String,Document> docs = new HashMap<String,Document>();
|
Map<String,Document> docs = new HashMap<String,Document>();
|
||||||
IndexWriter w = new MockIndexWriter(dir, newIndexWriterConfig(
|
IndexWriter w = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig(
|
||||||
TEST_VERSION_CURRENT, new MockAnalyzer(random())).setOpenMode(OpenMode.CREATE).setRAMBufferSizeMB(
|
TEST_VERSION_CURRENT, new MockAnalyzer(random())).setOpenMode(OpenMode.CREATE).setRAMBufferSizeMB(
|
||||||
0.1).setMaxBufferedDocs(maxBufferedDocs).setMergePolicy(newLogMergePolicy()));
|
0.1).setMaxBufferedDocs(maxBufferedDocs).setMergePolicy(newLogMergePolicy()), new YieldTestPoint());
|
||||||
w.commit();
|
w.commit();
|
||||||
LogMergePolicy lmp = (LogMergePolicy) w.getConfig().getMergePolicy();
|
LogMergePolicy lmp = (LogMergePolicy) w.getConfig().getMergePolicy();
|
||||||
lmp.setUseCompoundFile(false);
|
lmp.setUseCompoundFile(false);
|
||||||
|
@ -202,10 +197,10 @@ public class TestStressIndexing2 extends LuceneTestCase {
|
||||||
public Map<String,Document> indexRandom(int nThreads, int iterations, int range, Directory dir, int maxThreadStates,
|
public Map<String,Document> indexRandom(int nThreads, int iterations, int range, Directory dir, int maxThreadStates,
|
||||||
boolean doReaderPooling) throws IOException, InterruptedException {
|
boolean doReaderPooling) throws IOException, InterruptedException {
|
||||||
Map<String,Document> docs = new HashMap<String,Document>();
|
Map<String,Document> docs = new HashMap<String,Document>();
|
||||||
IndexWriter w = new MockIndexWriter(dir, newIndexWriterConfig(
|
IndexWriter w = RandomIndexWriter.mockIndexWriter(dir, newIndexWriterConfig(
|
||||||
TEST_VERSION_CURRENT, new MockAnalyzer(random())).setOpenMode(OpenMode.CREATE)
|
TEST_VERSION_CURRENT, new MockAnalyzer(random())).setOpenMode(OpenMode.CREATE)
|
||||||
.setRAMBufferSizeMB(0.1).setMaxBufferedDocs(maxBufferedDocs).setIndexerThreadPool(new ThreadAffinityDocumentsWriterThreadPool(maxThreadStates))
|
.setRAMBufferSizeMB(0.1).setMaxBufferedDocs(maxBufferedDocs).setIndexerThreadPool(new ThreadAffinityDocumentsWriterThreadPool(maxThreadStates))
|
||||||
.setReaderPooling(doReaderPooling).setMergePolicy(newLogMergePolicy()));
|
.setReaderPooling(doReaderPooling).setMergePolicy(newLogMergePolicy()), new YieldTestPoint());
|
||||||
LogMergePolicy lmp = (LogMergePolicy) w.getConfig().getMergePolicy();
|
LogMergePolicy lmp = (LogMergePolicy) w.getConfig().getMergePolicy();
|
||||||
lmp.setUseCompoundFile(false);
|
lmp.setUseCompoundFile(false);
|
||||||
lmp.setMergeFactor(mergeFactor);
|
lmp.setMergeFactor(mergeFactor);
|
||||||
|
|
|
@ -25,17 +25,12 @@ import java.util.Random;
|
||||||
import org.apache.lucene.analysis.Analyzer;
|
import org.apache.lucene.analysis.Analyzer;
|
||||||
import org.apache.lucene.analysis.MockAnalyzer;
|
import org.apache.lucene.analysis.MockAnalyzer;
|
||||||
import org.apache.lucene.codecs.Codec;
|
import org.apache.lucene.codecs.Codec;
|
||||||
import org.apache.lucene.document.BinaryDocValuesField;
|
|
||||||
import org.apache.lucene.document.Document;
|
|
||||||
import org.apache.lucene.document.Field;
|
|
||||||
import org.apache.lucene.document.NumericDocValuesField;
|
|
||||||
import org.apache.lucene.document.SortedDocValuesField;
|
|
||||||
import org.apache.lucene.index.FieldInfo.DocValuesType;
|
|
||||||
import org.apache.lucene.index.IndexWriter; // javadoc
|
import org.apache.lucene.index.IndexWriter; // javadoc
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.lucene.store.Directory;
|
import org.apache.lucene.store.Directory;
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.InfoStream;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
|
import org.apache.lucene.util.NullInfoStream;
|
||||||
import org.apache.lucene.util.Version;
|
import org.apache.lucene.util.Version;
|
||||||
import org.apache.lucene.util._TestUtil;
|
import org.apache.lucene.util._TestUtil;
|
||||||
|
|
||||||
|
@ -55,23 +50,22 @@ public class RandomIndexWriter implements Closeable {
|
||||||
private boolean getReaderCalled;
|
private boolean getReaderCalled;
|
||||||
private final Codec codec; // sugar
|
private final Codec codec; // sugar
|
||||||
|
|
||||||
|
|
||||||
|
public static IndexWriter mockIndexWriter(Directory dir, IndexWriterConfig conf, Random r) throws IOException {
|
||||||
// Randomly calls Thread.yield so we mixup thread scheduling
|
// Randomly calls Thread.yield so we mixup thread scheduling
|
||||||
private static final class MockIndexWriter extends IndexWriter {
|
final Random random = new Random(r.nextLong());
|
||||||
|
return mockIndexWriter(dir, conf, new TestPoint() {
|
||||||
private final Random r;
|
|
||||||
|
|
||||||
public MockIndexWriter(Random r, Directory dir, IndexWriterConfig conf) throws IOException {
|
|
||||||
super(dir, conf);
|
|
||||||
// TODO: this should be solved in a different way; Random should not be shared (!).
|
|
||||||
this.r = new Random(r.nextLong());
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean testPoint(String name) {
|
public void apply(String message) {
|
||||||
if (r.nextInt(4) == 2)
|
if (random.nextInt(4) == 2)
|
||||||
Thread.yield();
|
Thread.yield();
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public static IndexWriter mockIndexWriter(Directory dir, IndexWriterConfig conf, TestPoint testPoint) throws IOException {
|
||||||
|
conf.setInfoStream(new TestPointInfoStream(conf.getInfoStream(), testPoint));
|
||||||
|
return new IndexWriter(dir, conf);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** create a RandomIndexWriter with a random config: Uses TEST_VERSION_CURRENT and MockAnalyzer */
|
/** create a RandomIndexWriter with a random config: Uses TEST_VERSION_CURRENT and MockAnalyzer */
|
||||||
|
@ -93,7 +87,7 @@ public class RandomIndexWriter implements Closeable {
|
||||||
public RandomIndexWriter(Random r, Directory dir, IndexWriterConfig c) throws IOException {
|
public RandomIndexWriter(Random r, Directory dir, IndexWriterConfig c) throws IOException {
|
||||||
// TODO: this should be solved in a different way; Random should not be shared (!).
|
// TODO: this should be solved in a different way; Random should not be shared (!).
|
||||||
this.r = new Random(r.nextLong());
|
this.r = new Random(r.nextLong());
|
||||||
w = new MockIndexWriter(r, dir, c);
|
w = mockIndexWriter(dir, c, r);
|
||||||
flushAt = _TestUtil.nextInt(r, 10, 1000);
|
flushAt = _TestUtil.nextInt(r, 10, 1000);
|
||||||
codec = w.getConfig().getCodec();
|
codec = w.getConfig().getCodec();
|
||||||
if (LuceneTestCase.VERBOSE) {
|
if (LuceneTestCase.VERBOSE) {
|
||||||
|
@ -345,4 +339,42 @@ public class RandomIndexWriter implements Closeable {
|
||||||
public void forceMerge(int maxSegmentCount) throws IOException {
|
public void forceMerge(int maxSegmentCount) throws IOException {
|
||||||
w.forceMerge(maxSegmentCount);
|
w.forceMerge(maxSegmentCount);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final class TestPointInfoStream extends InfoStream {
|
||||||
|
private final InfoStream delegate;
|
||||||
|
private final TestPoint testPoint;
|
||||||
|
|
||||||
|
public TestPointInfoStream(InfoStream delegate, TestPoint testPoint) {
|
||||||
|
this.delegate = delegate == null ? new NullInfoStream(): delegate;
|
||||||
|
this.testPoint = testPoint;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void close() throws IOException {
|
||||||
|
delegate.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void message(String component, String message) {
|
||||||
|
if ("TP".equals(component)) {
|
||||||
|
testPoint.apply(message);
|
||||||
|
}
|
||||||
|
if (delegate.isEnabled(component)) {
|
||||||
|
delegate.message(component, message);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isEnabled(String component) {
|
||||||
|
return "TP".equals(component) || delegate.isEnabled(component);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Simple interface that is executed for each <tt>TP</tt> {@link InfoStream} component
|
||||||
|
* message. See also {@link RandomIndexWriter#mockIndexWriter(Directory, IndexWriterConfig, TestPoint)}
|
||||||
|
*/
|
||||||
|
public static interface TestPoint {
|
||||||
|
public abstract void apply(String message);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue