mirror of https://github.com/apache/lucene.git
SOLR-10028: Fix and improvements to SegmentsInfoRequestHandlerTest
This commit is contained in:
parent
659aed2de1
commit
d833b4c9d3
|
@ -254,6 +254,8 @@ Bug Fixes
|
||||||
* SOLR-12683: HashQuery will throw an exception if more than 4 partitionKeys is specified.
|
* SOLR-12683: HashQuery will throw an exception if more than 4 partitionKeys is specified.
|
||||||
Earlier after the 4th partitionKey the keys would be silently ignored. (Varun Thacker)
|
Earlier after the 4th partitionKey the keys would be silently ignored. (Varun Thacker)
|
||||||
|
|
||||||
|
* SOLR-10028: Fix and improvements to SegmentsInfoRequestHandlerTest (Christine Poerschke, Tomás Fernández Löbbe)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -16,10 +16,13 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.handler.admin;
|
package org.apache.solr.handler.admin;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import org.apache.lucene.index.SegmentCommitInfo;
|
||||||
|
import org.apache.lucene.index.SegmentInfos;
|
||||||
import org.apache.lucene.util.Version;
|
import org.apache.lucene.util.Version;
|
||||||
import org.apache.solr.index.LogDocMergePolicyFactory;
|
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
|
import org.apache.solr.index.NoMergePolicyFactory;
|
||||||
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
|
@ -31,13 +34,18 @@ public class SegmentsInfoRequestHandlerTest extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
private static final int DEL_COUNT = 1;
|
private static final int DEL_COUNT = 1;
|
||||||
|
|
||||||
|
private static final int NUM_SEGMENTS = 2;
|
||||||
|
|
||||||
@BeforeClass
|
@BeforeClass
|
||||||
public static void beforeClass() throws Exception {
|
public static void beforeClass() throws Exception {
|
||||||
|
|
||||||
// we need a consistent segmentation to ensure we don't get a random
|
// we need a consistent segmentation to ensure we don't get a random
|
||||||
// merge that reduces the total num docs in all segments, or the number of deletes
|
// merge that reduces the total num docs in all segments, or the number of deletes
|
||||||
//
|
//
|
||||||
systemSetPropertySolrTestsMergePolicyFactory(LogDocMergePolicyFactory.class.getName());
|
systemSetPropertySolrTestsMergePolicyFactory(NoMergePolicyFactory.class.getName());
|
||||||
|
// Also prevent flushes
|
||||||
|
System.setProperty("solr.tests.maxBufferedDocs", "1000");
|
||||||
|
System.setProperty("solr.tests.ramBufferSizeMB", "5000");
|
||||||
|
|
||||||
System.setProperty("enable.update.log", "false"); // no _version_ in our schema
|
System.setProperty("enable.update.log", "false"); // no _version_ in our schema
|
||||||
initCore("solrconfig.xml", "schema12.xml"); // segments API shouldn't depend on _version_ or ulog
|
initCore("solrconfig.xml", "schema12.xml"); // segments API shouldn't depend on _version_ or ulog
|
||||||
|
@ -54,25 +62,58 @@ public class SegmentsInfoRequestHandlerTest extends SolrTestCaseJ4 {
|
||||||
assertU(adoc("id","SOLR200" + i, "name","Apache Solr:" + i));
|
assertU(adoc("id","SOLR200" + i, "name","Apache Solr:" + i));
|
||||||
}
|
}
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
|
h.getCore().withSearcher((searcher) -> {
|
||||||
|
int numSegments = SegmentInfos.readLatestCommit(searcher.getIndexReader().directory()).size();
|
||||||
|
// if this is not NUM_SEGMENTS, there was some unexpected flush or merge
|
||||||
|
assertEquals("Unexpected number of segment in the index: " + numSegments,
|
||||||
|
NUM_SEGMENTS, numSegments);
|
||||||
|
return null;
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@AfterClass
|
||||||
|
public static void afterClass() {
|
||||||
|
systemClearPropertySolrTestsMergePolicyFactory();
|
||||||
|
System.clearProperty("solr.tests.maxBufferedDocs");
|
||||||
|
System.clearProperty("solr.tests.ramBufferSizeMB");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSegmentInfos() {
|
public void testSegmentInfos() {
|
||||||
assertQ("No segments mentioned in result",
|
assertQ("Unexpected number of segments returned",
|
||||||
req("qt","/admin/segments"),
|
req("qt","/admin/segments"),
|
||||||
"0<count(//lst[@name='segments']/lst)");
|
NUM_SEGMENTS + "=count(//lst[@name='segments']/lst)");
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSegmentInfosVersion() {
|
public void testSegmentInfosVersion() {
|
||||||
assertQ("No segments mentioned in result",
|
assertQ("Unexpected number of segments returned",
|
||||||
req("qt","/admin/segments"),
|
req("qt","/admin/segments"),
|
||||||
"2=count(//lst[@name='segments']/lst/str[@name='version'][.='"+Version.LATEST+"'])");
|
NUM_SEGMENTS + "=count(//lst[@name='segments']/lst/str[@name='version'][.='" + Version.LATEST + "'])");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testSegmentNames() throws IOException {
|
||||||
|
String[] segmentNamePatterns = new String[NUM_SEGMENTS];
|
||||||
|
h.getCore().withSearcher((searcher) -> {
|
||||||
|
int i = 0;
|
||||||
|
for (SegmentCommitInfo sInfo : SegmentInfos.readLatestCommit(searcher.getIndexReader().directory())) {
|
||||||
|
assertTrue("Unexpected number of segment in the index: " + i, i < NUM_SEGMENTS);
|
||||||
|
segmentNamePatterns[i] = "//lst[@name='segments']/lst/str[@name='name'][.='" + sInfo.info.name + "']";
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
});
|
||||||
|
assertQ("Unexpected segment names returned",
|
||||||
|
req("qt","/admin/segments"),
|
||||||
|
segmentNamePatterns);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testSegmentInfosData() {
|
public void testSegmentInfosData() {
|
||||||
assertQ("No segments mentioned in result",
|
assertQ("Unexpected document counts in result",
|
||||||
req("qt","/admin/segments"),
|
req("qt","/admin/segments"),
|
||||||
//#Document
|
//#Document
|
||||||
(DOC_COUNT*2)+"=sum(//lst[@name='segments']/lst/int[@name='size'])",
|
(DOC_COUNT*2)+"=sum(//lst[@name='segments']/lst/int[@name='size'])",
|
||||||
|
|
Loading…
Reference in New Issue