mirror of https://github.com/apache/lucene.git
SOLR-11289: fix comma handling in terms component
This commit is contained in:
parent
7f52920352
commit
a7cc9c3631
solr
|
@ -103,6 +103,8 @@ Bug Fixes
|
||||||
|
|
||||||
* SOLR-11272: fix NPE when EmbeddedSolrServer handles /admin/* request and so one (Stephen Allen via Mikhail Khludnev)
|
* SOLR-11272: fix NPE when EmbeddedSolrServer handles /admin/* request and so one (Stephen Allen via Mikhail Khludnev)
|
||||||
|
|
||||||
|
* SOLR-11289: fix comma handling in terms component. (yonik)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -590,11 +590,13 @@ public class TermsComponent extends SearchComponent {
|
||||||
|
|
||||||
private static void fetchTerms(SolrIndexSearcher indexSearcher, String[] fields, String termList,
|
private static void fetchTerms(SolrIndexSearcher indexSearcher, String[] fields, String termList,
|
||||||
boolean includeTotalTermFreq, NamedList<Object> result) throws IOException {
|
boolean includeTotalTermFreq, NamedList<Object> result) throws IOException {
|
||||||
String[] splitTerms = termList.split(",");
|
List<String> splitTermList = StrUtils.splitSmart(termList, ",", true);
|
||||||
|
// Sort the terms once
|
||||||
|
String[] splitTerms = splitTermList.toArray(new String[splitTermList.size()]);
|
||||||
|
// Not a great idea to trim here, but it was in the original implementation
|
||||||
for (int i = 0; i < splitTerms.length; i++) {
|
for (int i = 0; i < splitTerms.length; i++) {
|
||||||
splitTerms[i] = splitTerms[i].trim();
|
splitTerms[i] = splitTerms[i].trim();
|
||||||
}
|
}
|
||||||
// Sort the terms once
|
|
||||||
Arrays.sort(splitTerms);
|
Arrays.sort(splitTerms);
|
||||||
|
|
||||||
IndexReaderContext topReaderContext = indexSearcher.getTopReaderContext();
|
IndexReaderContext topReaderContext = indexSearcher.getTopReaderContext();
|
||||||
|
|
|
@ -33,7 +33,7 @@ public class DistributedTermsComponentTest extends BaseDistributedSearchTestCase
|
||||||
public void test() throws Exception {
|
public void test() throws Exception {
|
||||||
|
|
||||||
del("*:*");
|
del("*:*");
|
||||||
index(id, 18, "b_t", "snake spider shark snail slug seal", "foo_i", "1");
|
index(id, 18, "b_t", "snake a,b spider shark snail slug seal", "foo_i", "1");
|
||||||
index(id, 19, "b_t", "snake spider shark snail slug", "foo_i", "2");
|
index(id, 19, "b_t", "snake spider shark snail slug", "foo_i", "2");
|
||||||
index(id, 20, "b_t", "snake spider shark snail", "foo_i", "3");
|
index(id, 20, "b_t", "snake spider shark snail", "foo_i", "3");
|
||||||
index(id, 21, "b_t", "snake spider shark", "foo_i", "2");
|
index(id, 21, "b_t", "snake spider shark", "foo_i", "2");
|
||||||
|
@ -53,10 +53,10 @@ public class DistributedTermsComponentTest extends BaseDistributedSearchTestCase
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms.limit", 5, "terms", "true", "terms.fl", "b_t", "terms.prefix", "s", "terms.lower", "s", "terms.sort", "index");
|
query("qt", "/terms", "shards.qt", "/terms", "terms.limit", 5, "terms", "true", "terms.fl", "b_t", "terms.prefix", "s", "terms.lower", "s", "terms.sort", "index");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms.limit", 5, "terms", "true", "terms.fl", "b_t", "terms.prefix", "s", "terms.lower", "s", "terms.upper", "sn", "terms.sort", "index");
|
query("qt", "/terms", "shards.qt", "/terms", "terms.limit", 5, "terms", "true", "terms.fl", "b_t", "terms.prefix", "s", "terms.lower", "s", "terms.upper", "sn", "terms.sort", "index");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.sort", "index");
|
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.sort", "index");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.list", "snake, zebra, ant, bad");
|
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.list", "snake,zebra,ant,bad");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "foo_i", "terms.list", "2, 3, 1");
|
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "foo_i", "terms.list", "2,3,1");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "foo_i", "terms.stats", "true","terms.list", "2, 3, 1");
|
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "foo_i", "terms.stats", "true","terms.list", "2,3,1");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.list", "snake, zebra", "terms.ttf", "true");
|
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.list", "snake,zebra", "terms.ttf", "true");
|
||||||
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.fl", "c_t", "terms.list", "snake, ant, zebra", "terms.ttf", "true");
|
query("qt", "/terms", "shards.qt", "/terms", "terms", "true", "terms.fl", "b_t", "terms.fl", "c_t", "terms.list", "snake,ant,zebra", "terms.ttf", "true");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -70,7 +70,8 @@ public class TermsComponentTest extends SolrTestCaseJ4 {
|
||||||
assertNull(h.validateUpdate(adoc("id", "20", "standardfilt", "snake")));
|
assertNull(h.validateUpdate(adoc("id", "20", "standardfilt", "snake")));
|
||||||
assertNull(h.validateUpdate(adoc("id", "21", "standardfilt", "snake")));
|
assertNull(h.validateUpdate(adoc("id", "21", "standardfilt", "snake")));
|
||||||
assertNull(h.validateUpdate(adoc("id", "22", "standardfilt", "shark")));
|
assertNull(h.validateUpdate(adoc("id", "22", "standardfilt", "shark")));
|
||||||
|
assertNull(h.validateUpdate(adoc("id", "23", "standardfilt", "a,b")));
|
||||||
|
|
||||||
assertNull(h.validateUpdate(commit()));
|
assertNull(h.validateUpdate(commit()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +95,7 @@ public class TermsComponentTest extends SolrTestCaseJ4 {
|
||||||
"terms.fl","lowerfilt", "terms.upper","b",
|
"terms.fl","lowerfilt", "terms.upper","b",
|
||||||
"terms.fl","standardfilt")
|
"terms.fl","standardfilt")
|
||||||
,"count(//lst[@name='lowerfilt']/*)=6"
|
,"count(//lst[@name='lowerfilt']/*)=6"
|
||||||
,"count(//lst[@name='standardfilt']/*)=4"
|
,"count(//lst[@name='standardfilt']/*)=5"
|
||||||
);
|
);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -178,19 +179,20 @@ public class TermsComponentTest extends SolrTestCaseJ4 {
|
||||||
//Terms list always returns in index order
|
//Terms list always returns in index order
|
||||||
assertQ(req("indent","true", "qt","/terms", "terms","true",
|
assertQ(req("indent","true", "qt","/terms", "terms","true",
|
||||||
"terms.fl","standardfilt",
|
"terms.fl","standardfilt",
|
||||||
"terms.list","spider, snake, shark, ddddd, bad")
|
"terms.list","spider,snake,a\\,b,shark,ddddd,bad")
|
||||||
,"count(//lst[@name='standardfilt']/*)=4"
|
,"count(//lst[@name='standardfilt']/*)=5"
|
||||||
,"//lst[@name='standardfilt']/int[1][@name='ddddd'][.='4']"
|
,"//lst[@name='standardfilt']/int[1][@name='a,b'][.='1']"
|
||||||
,"//lst[@name='standardfilt']/int[2][@name='shark'][.='2']"
|
,"//lst[@name='standardfilt']/int[2][@name='ddddd'][.='4']"
|
||||||
,"//lst[@name='standardfilt']/int[3][@name='snake'][.='3']"
|
,"//lst[@name='standardfilt']/int[3][@name='shark'][.='2']"
|
||||||
,"//lst[@name='standardfilt']/int[4][@name='spider'][.='1']"
|
,"//lst[@name='standardfilt']/int[4][@name='snake'][.='3']"
|
||||||
|
,"//lst[@name='standardfilt']/int[5][@name='spider'][.='1']"
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
//Test with numeric terms
|
//Test with numeric terms
|
||||||
assertQ(req("indent","true", "qt","/terms", "terms","true",
|
assertQ(req("indent","true", "qt","/terms", "terms","true",
|
||||||
"terms.fl","foo_i",
|
"terms.fl","foo_i",
|
||||||
"terms.list","2, 1")
|
"terms.list","2,1")
|
||||||
,"count(//lst[@name='foo_i']/*)=2"
|
,"count(//lst[@name='foo_i']/*)=2"
|
||||||
,"//lst[@name='foo_i']/int[1][@name='1'][.='2']"
|
,"//lst[@name='foo_i']/int[1][@name='1'][.='2']"
|
||||||
,"//lst[@name='foo_i']/int[2][@name='2'][.='1']"
|
,"//lst[@name='foo_i']/int[2][@name='2'][.='1']"
|
||||||
|
@ -203,8 +205,8 @@ public class TermsComponentTest extends SolrTestCaseJ4 {
|
||||||
//Terms list always returns in index order
|
//Terms list always returns in index order
|
||||||
assertQ(req("indent", "true", "qt", "/terms", "terms", "true",
|
assertQ(req("indent", "true", "qt", "/terms", "terms", "true",
|
||||||
"terms.fl", "standardfilt","terms.stats", "true",
|
"terms.fl", "standardfilt","terms.stats", "true",
|
||||||
"terms.list", "spider, snake, shark, ddddd, bad")
|
"terms.list", "spider,snake,shark,ddddd,bad")
|
||||||
, "//lst[@name='indexstats']/long[1][@name='numDocs'][.='23']"
|
, "//lst[@name='indexstats']/long[1][@name='numDocs'][.='24']"
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue