mirror of https://github.com/apache/lucene.git
sequence numbers: improve test debuggability, IW javadocs
This commit is contained in:
parent
0b9c0dd522
commit
4bdd08a9a6
|
@ -2928,7 +2928,7 @@ public class IndexWriter implements Closeable, TwoPhaseCommit, Accountable {
|
||||||
* will internally call prepareCommit.
|
* will internally call prepareCommit.
|
||||||
*
|
*
|
||||||
* @return The <a href="#sequence_number">sequence number</a>
|
* @return The <a href="#sequence_number">sequence number</a>
|
||||||
* last operation in the commit. All sequence numbers <= this value
|
* of the last operation in the commit. All sequence numbers <= this value
|
||||||
* will be reflected in the commit, and all others will not.
|
* will be reflected in the commit, and all others will not.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
@ -3128,7 +3128,7 @@ public class IndexWriter implements Closeable, TwoPhaseCommit, Accountable {
|
||||||
* @see #prepareCommit
|
* @see #prepareCommit
|
||||||
*
|
*
|
||||||
* @return The <a href="#sequence_number">sequence number</a>
|
* @return The <a href="#sequence_number">sequence number</a>
|
||||||
* last operation in the commit. All sequence numbers <= this value
|
* of the last operation in the commit. All sequence numbers <= this value
|
||||||
* will be reflected in the commit, and all others will not.
|
* will be reflected in the commit, and all others will not.
|
||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -165,7 +165,8 @@ public class TestIndexingSequenceNumbers extends LuceneTestCase {
|
||||||
Object commitLock = new Object();
|
Object commitLock = new Object();
|
||||||
final List<Operation> commits = new ArrayList<>();
|
final List<Operation> commits = new ArrayList<>();
|
||||||
|
|
||||||
// multiple threads update the same set of documents, and we randomly commit
|
// multiple threads update the same set of documents, and we randomly commit, recording the commit seqNo and then opening each commit in
|
||||||
|
// the end to verify it reflects the correct updates
|
||||||
for(int i=0;i<threads.length;i++) {
|
for(int i=0;i<threads.length;i++) {
|
||||||
final List<Operation> ops = new ArrayList<>();
|
final List<Operation> ops = new ArrayList<>();
|
||||||
threadOps.add(ops);
|
threadOps.add(ops);
|
||||||
|
@ -326,6 +327,7 @@ public class TestIndexingSequenceNumbers extends LuceneTestCase {
|
||||||
List<Operation> ops1 = new ArrayList<>();
|
List<Operation> ops1 = new ArrayList<>();
|
||||||
threadOps.add(ops1);
|
threadOps.add(ops1);
|
||||||
|
|
||||||
|
// pre-index every ID so none are missing:
|
||||||
for(int id=0;id<idCount;id++) {
|
for(int id=0;id<idCount;id++) {
|
||||||
int threadID = 0;
|
int threadID = 0;
|
||||||
Operation op = new Operation();
|
Operation op = new Operation();
|
||||||
|
@ -340,7 +342,8 @@ public class TestIndexingSequenceNumbers extends LuceneTestCase {
|
||||||
ops1.add(op);
|
ops1.add(op);
|
||||||
}
|
}
|
||||||
|
|
||||||
// multiple threads update the same set of documents, and we randomly commit
|
// multiple threads update the same set of documents, and we randomly commit, recording the commit seqNo and then opening each commit in
|
||||||
|
// the end to verify it reflects the correct updates
|
||||||
for(int i=0;i<threads.length;i++) {
|
for(int i=0;i<threads.length;i++) {
|
||||||
final List<Operation> ops;
|
final List<Operation> ops;
|
||||||
if (i == 0) {
|
if (i == 0) {
|
||||||
|
@ -431,31 +434,21 @@ public class TestIndexingSequenceNumbers extends LuceneTestCase {
|
||||||
//System.out.println("TEST: check id=" + id + " expectedThreadID=" + expectedThreadIDs[id]);
|
//System.out.println("TEST: check id=" + id + " expectedThreadID=" + expectedThreadIDs[id]);
|
||||||
TopDocs hits = s.search(new TermQuery(new Term("id", ""+id)), 1);
|
TopDocs hits = s.search(new TermQuery(new Term("id", ""+id)), 1);
|
||||||
|
|
||||||
if (expectedThreadIDs[id] != -1) {
|
// We pre-add all ids up front:
|
||||||
|
assert expectedThreadIDs[id] != -1;
|
||||||
assertEquals(1, hits.totalHits);
|
assertEquals(1, hits.totalHits);
|
||||||
int actualThreadID = (int) docValues.get(id);
|
int actualThreadID = (int) docValues.get(id);
|
||||||
if (expectedThreadIDs[id] != actualThreadID) {
|
if (expectedThreadIDs[id] != actualThreadID) {
|
||||||
System.out.println("FAIL: id=" + id + " expectedThreadID=" + expectedThreadIDs[id] + " vs actualThreadID=" + actualThreadID + " commitSeqNo=" + commitSeqNo + " numThreads=" + numThreads);
|
System.out.println("FAIL: commit=" + i + " (of " + commits.size() + ") id=" + id + " expectedThreadID=" + expectedThreadIDs[id] + " vs actualThreadID=" + actualThreadID + " commitSeqNo=" + commitSeqNo + " numThreads=" + numThreads);
|
||||||
for(int threadID=0;threadID<threadOps.size();threadID++) {
|
for(int threadID=0;threadID<threadOps.size();threadID++) {
|
||||||
for(Operation op : threadOps.get(threadID)) {
|
for(Operation op : threadOps.get(threadID)) {
|
||||||
if (id == op.id) {
|
if (id == op.id) {
|
||||||
System.out.println(" threadID=" + threadID + " seqNo=" + op.seqNo + " " + (op.what == 2 ? "updated" : "deleted"));
|
System.out.println(" threadID=" + threadID + " seqNo=" + op.seqNo);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
assertEquals("id=" + id, expectedThreadIDs[id], actualThreadID);
|
assertEquals("id=" + id, expectedThreadIDs[id], actualThreadID);
|
||||||
}
|
}
|
||||||
} else if (hits.totalHits != 0) {
|
|
||||||
System.out.println("FAIL: id=" + id + " expectedThreadID=" + expectedThreadIDs[id] + " vs totalHits=" + hits.totalHits + " commitSeqNo=" + commitSeqNo + " numThreads=" + numThreads);
|
|
||||||
for(int threadID=0;threadID<threadOps.size();threadID++) {
|
|
||||||
for(Operation op : threadOps.get(threadID)) {
|
|
||||||
if (id == op.id) {
|
|
||||||
System.out.println(" threadID=" + threadID + " seqNo=" + op.seqNo + " " + (op.what == 2 ? "updated" : "del"));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
assertEquals(0, hits.totalHits);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
w.close();
|
w.close();
|
||||||
r.close();
|
r.close();
|
||||||
|
|
Loading…
Reference in New Issue