mirror of https://github.com/apache/lucene.git
SOLR-13261: Make SortableTextField work with export/streaming, now requires useDocValuesAsStored='true'
This commit is contained in:
parent
db5f1af59b
commit
1e09268e78
|
@ -62,7 +62,8 @@ New Features
|
||||||
|
|
||||||
* SOLR-13171 : A true streaming parser for javabin payload/stream without creating any objects (noble)
|
* SOLR-13171 : A true streaming parser for javabin payload/stream without creating any objects (noble)
|
||||||
|
|
||||||
* SOLR-13261: Make SortableTextField work with export/streaming
|
* SOLR-13261: Make SortableTextField work with export/streaming. NOTE: requires that the field have
|
||||||
|
useDocValuesAsStored=true (either explicit or as the default).
|
||||||
|
|
||||||
* SOLR-10436: Add hashRollup Streaming Expression (Joel Bernstein)
|
* SOLR-10436: Add hashRollup Streaming Expression (Joel Bernstein)
|
||||||
|
|
||||||
|
|
|
@ -332,9 +332,13 @@ public class ExportWriter implements SolrCore.RawWriter, Closeable {
|
||||||
if (!schemaField.hasDocValues()) {
|
if (!schemaField.hasDocValues()) {
|
||||||
throw new IOException(schemaField + " must have DocValues to use this feature.");
|
throw new IOException(schemaField + " must have DocValues to use this feature.");
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean multiValued = schemaField.multiValued();
|
boolean multiValued = schemaField.multiValued();
|
||||||
FieldType fieldType = schemaField.getType();
|
FieldType fieldType = schemaField.getType();
|
||||||
|
|
||||||
|
if (fieldType instanceof SortableTextField && schemaField.useDocValuesAsStored() == false) {
|
||||||
|
throw new IOException(schemaField + " Must have useDocValuesAsStored='true' to be used with export writer");
|
||||||
|
}
|
||||||
|
|
||||||
if (fieldType instanceof IntValueFieldType) {
|
if (fieldType instanceof IntValueFieldType) {
|
||||||
if (multiValued) {
|
if (multiValued) {
|
||||||
writers[i] = new MultiFieldWriter(field, fieldType, schemaField, true);
|
writers[i] = new MultiFieldWriter(field, fieldType, schemaField, true);
|
||||||
|
@ -398,6 +402,10 @@ public class ExportWriter implements SolrCore.RawWriter, Closeable {
|
||||||
throw new IOException(field + " must have DocValues to use this feature.");
|
throw new IOException(field + " must have DocValues to use this feature.");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (ft instanceof SortableTextField && schemaField.useDocValuesAsStored() == false) {
|
||||||
|
throw new IOException(schemaField + " Must have useDocValuesAsStored='true' to be used with export writer");
|
||||||
|
}
|
||||||
|
|
||||||
if (ft instanceof IntValueFieldType) {
|
if (ft instanceof IntValueFieldType) {
|
||||||
if (reverse) {
|
if (reverse) {
|
||||||
sortValues[i] = new IntValue(field, new IntDesc());
|
sortValues[i] = new IntValue(field, new IntDesc());
|
||||||
|
|
|
@ -69,6 +69,8 @@
|
||||||
<field name="datedv_m" type="date" indexed="false" stored="false" docValues="true" multiValued="true"/>
|
<field name="datedv_m" type="date" indexed="false" stored="false" docValues="true" multiValued="true"/>
|
||||||
<field name="stringdv_m" type="string" indexed="false" stored="false" docValues="true" multiValued="true"/>
|
<field name="stringdv_m" type="string" indexed="false" stored="false" docValues="true" multiValued="true"/>
|
||||||
<field name="sortabledv_m" type="text_gen_sort" indexed="true" stored="true" multiValued="true" />
|
<field name="sortabledv_m" type="text_gen_sort" indexed="true" stored="true" multiValued="true" />
|
||||||
|
<field name="sortabledv_m_udvas" type="text_gen_sort" indexed="true" stored="true" multiValued="true" useDocValuesAsStored="true"/>
|
||||||
|
|
||||||
|
|
||||||
<field name="floatdv" type="float" indexed="false" stored="false" docValues="true"/>
|
<field name="floatdv" type="float" indexed="false" stored="false" docValues="true"/>
|
||||||
<field name="intdv" type="int" indexed="false" stored="false" docValues="true"/>
|
<field name="intdv" type="int" indexed="false" stored="false" docValues="true"/>
|
||||||
|
@ -78,6 +80,7 @@
|
||||||
<field name="stringdv" type="string" indexed="false" stored="false" docValues="true"/>
|
<field name="stringdv" type="string" indexed="false" stored="false" docValues="true"/>
|
||||||
<field name="booleandv" type="boolean" indexed="false" stored="false" docValues="true" />
|
<field name="booleandv" type="boolean" indexed="false" stored="false" docValues="true" />
|
||||||
<field name="sortabledv" type="text_gen_sort" indexed="true" stored="true" multiValued="false" />
|
<field name="sortabledv" type="text_gen_sort" indexed="true" stored="true" multiValued="false" />
|
||||||
|
<field name="sortabledv_udvas" type="text_gen_sort" indexed="true" stored="true" multiValued="false" useDocValuesAsStored="true" />
|
||||||
|
|
||||||
<dynamicField name="*_s_dv" type="string" indexed="true" stored="true" docValues="true" multiValued="false"/>
|
<dynamicField name="*_s_dv" type="string" indexed="true" stored="true" docValues="true" multiValued="false"/>
|
||||||
|
|
||||||
|
|
|
@ -132,7 +132,10 @@ public class TestExportWriter extends SolrTestCaseJ4 {
|
||||||
"datedv_m", "2017-06-16T04:00:00Z",
|
"datedv_m", "2017-06-16T04:00:00Z",
|
||||||
"sortabledv_m", "this is some text one_1",
|
"sortabledv_m", "this is some text one_1",
|
||||||
"sortabledv_m", "this is some text two_1",
|
"sortabledv_m", "this is some text two_1",
|
||||||
"sortabledv_m", "this is some text three_1"));
|
"sortabledv_m", "this is some text three_1",
|
||||||
|
"sortabledv_m_udvas", "this is some text one_1",
|
||||||
|
"sortabledv_m_udvas", "this is some text two_1",
|
||||||
|
"sortabledv_m_udvas", "this is some text three_1"));
|
||||||
|
|
||||||
assertU(adoc("id","7",
|
assertU(adoc("id","7",
|
||||||
"floatdv","2.1",
|
"floatdv","2.1",
|
||||||
|
@ -170,7 +173,8 @@ public class TestExportWriter extends SolrTestCaseJ4 {
|
||||||
"int_is_t", "1",
|
"int_is_t", "1",
|
||||||
"int_is_t", "1",
|
"int_is_t", "1",
|
||||||
"int_is_t", "1",
|
"int_is_t", "1",
|
||||||
"sortabledv", "this is some text_1"));
|
"sortabledv", "this is some text_1",
|
||||||
|
"sortabledv_udvas", "this is some text_1"));
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
assertU(adoc("id","8",
|
assertU(adoc("id","8",
|
||||||
"floatdv","2.1",
|
"floatdv","2.1",
|
||||||
|
@ -197,9 +201,14 @@ public class TestExportWriter extends SolrTestCaseJ4 {
|
||||||
"int_is_p", "1",
|
"int_is_p", "1",
|
||||||
"int_is_p", "1",
|
"int_is_p", "1",
|
||||||
"sortabledv", "this is some text_2",
|
"sortabledv", "this is some text_2",
|
||||||
|
"sortabledv_udvas", "this is some text_2",
|
||||||
"sortabledv_m", "this is some text one_2",
|
"sortabledv_m", "this is some text one_2",
|
||||||
"sortabledv_m", "this is some text two_2",
|
"sortabledv_m", "this is some text two_2",
|
||||||
"sortabledv_m", "this is some text three_2"));
|
"sortabledv_m", "this is some text three_2",
|
||||||
|
"sortabledv_m_udvas", "this is some text one_2",
|
||||||
|
"sortabledv_m_udvas", "this is some text two_2",
|
||||||
|
"sortabledv_m_udvas", "this is some text three_2"
|
||||||
|
));
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
|
|
||||||
|
|
||||||
|
@ -501,22 +510,31 @@ public class TestExportWriter extends SolrTestCaseJ4 {
|
||||||
assertJsonEquals(s, "{\"responseHeader\": {\"status\": 0}, \"response\":{\"numFound\":1, \"docs\":[{\"stringdv\":\"chello \\\"world\\\"\"}]}}");
|
assertJsonEquals(s, "{\"responseHeader\": {\"status\": 0}, \"response\":{\"numFound\":1, \"docs\":[{\"stringdv\":\"chello \\\"world\\\"\"}]}}");
|
||||||
|
|
||||||
// Test sortable text fields:
|
// Test sortable text fields:
|
||||||
s = h.query(req("q", "id:(1 OR 3 OR 8)", "qt", "/export", "fl", "sortabledv_m,sortabledv", "sort", "sortabledv asc"));
|
s = h.query(req("q", "id:(1 OR 3 OR 8)", "qt", "/export", "fl", "sortabledv_m_udvas,sortabledv_udvas", "sort", "sortabledv_udvas asc"));
|
||||||
assertJsonEquals(s, "{\n" +
|
assertJsonEquals(s, "{\n" +
|
||||||
" \"responseHeader\":{\"status\":0},\n" +
|
" \"responseHeader\":{\"status\":0},\n" +
|
||||||
" \"response\":{\n" +
|
" \"response\":{\n" +
|
||||||
" \"numFound\":3,\n" +
|
" \"numFound\":3,\n" +
|
||||||
" \"docs\":[{\n" +
|
" \"docs\":[{\n" +
|
||||||
" \"sortabledv_m\":[\"this is some text one_1\"\n" +
|
" \"sortabledv_m_udvas\":[\"this is some text one_1\"\n" +
|
||||||
" ,\"this is some text three_1\"\n" +
|
" ,\"this is some text three_1\"\n" +
|
||||||
" ,\"this is some text two_1\"]}\n" +
|
" ,\"this is some text two_1\"]}\n" +
|
||||||
" ,{\n" +
|
" ,{\n" +
|
||||||
" \"sortabledv\":\"this is some text_1\"}\n" +
|
" \"sortabledv_udvas\":\"this is some text_1\"}\n" +
|
||||||
" ,{\n" +
|
" ,{\n" +
|
||||||
" \"sortabledv_m\":[\"this is some text one_2\"\n" +
|
" \"sortabledv_m_udvas\":[\"this is some text one_2\"\n" +
|
||||||
" ,\"this is some text three_2\"\n" +
|
" ,\"this is some text three_2\"\n" +
|
||||||
" ,\"this is some text two_2\"],\n" +
|
" ,\"this is some text two_2\"],\n" +
|
||||||
" \"sortabledv\":\"this is some text_2\"}]}}");
|
" \"sortabledv_udvas\":\"this is some text_2\"}]}}");
|
||||||
|
|
||||||
|
s = h.query(req("q", "id:(1 OR 3 OR 8)", "qt", "/export", "fl", "sortabledv_m", "sort", "sortabledv_udvas asc"));
|
||||||
|
assertTrue("Should have 400 status when exporting sortabledv_m, it does not have useDocValuesAsStored='true'", s.contains("\"status\":400}"));
|
||||||
|
assertTrue("Should have a cause when exporting sortabledv_m, it does not have useDocValuesAsStored='true'", s.contains("Must have useDocValuesAsStored='true' to be used with export writer"));
|
||||||
|
|
||||||
|
s = h.query(req("q", "id:(1 OR 3 OR 8)", "qt", "/export", "fl", "sortabledv", "sort", "sortabledv_udvas asc"));
|
||||||
|
assertTrue("Should have 400 status when exporting sortabledv, it does not have useDocValuesAsStored='true'", s.contains("\"status\":400}"));
|
||||||
|
assertTrue("Should have a cause when exporting sortabledv, it does not have useDocValuesAsStored='true'", s.contains("Must have useDocValuesAsStored='true' to be used with export writer"));
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void assertJsonEquals(String actual, String expected) {
|
private void assertJsonEquals(String actual, String expected) {
|
||||||
|
|
Loading…
Reference in New Issue