mirror of https://github.com/apache/lucene.git
SOLR-13538: Fix classcastEx in TrieDateField for atomic updates (#764)
SOLR-13538: toNativeType () TrieDate & EnumField do not handle CharSequence properly
This commit is contained in:
parent
36af839eb1
commit
5f1d342a96
|
@ -17,6 +17,10 @@
|
||||||
|
|
||||||
package org.apache.solr.schema;
|
package org.apache.solr.schema;
|
||||||
|
|
||||||
|
import javax.xml.xpath.XPath;
|
||||||
|
import javax.xml.xpath.XPathConstants;
|
||||||
|
import javax.xml.xpath.XPathExpressionException;
|
||||||
|
import javax.xml.xpath.XPathFactory;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -24,11 +28,6 @@ import java.util.HashMap;
|
||||||
import java.util.Locale;
|
import java.util.Locale;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import javax.xml.xpath.XPath;
|
|
||||||
import javax.xml.xpath.XPathConstants;
|
|
||||||
import javax.xml.xpath.XPathExpressionException;
|
|
||||||
import javax.xml.xpath.XPathFactory;
|
|
||||||
|
|
||||||
import org.apache.commons.lang3.math.NumberUtils;
|
import org.apache.commons.lang3.math.NumberUtils;
|
||||||
import org.apache.lucene.index.IndexableField;
|
import org.apache.lucene.index.IndexableField;
|
||||||
import org.apache.lucene.queries.function.ValueSource;
|
import org.apache.lucene.queries.function.ValueSource;
|
||||||
|
@ -314,7 +313,7 @@ public abstract class AbstractEnumField extends PrimitiveFieldType {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object toNativeType(Object val) {
|
public Object toNativeType(Object val) {
|
||||||
if (val instanceof CharSequence || val instanceof String) {
|
if (val instanceof CharSequence) {
|
||||||
final String str = val.toString();
|
final String str = val.toString();
|
||||||
final Integer entry = enumMapping.enumStringToIntMap.get(str);
|
final Integer entry = enumMapping.enumStringToIntMap.get(str);
|
||||||
if (entry != null) {
|
if (entry != null) {
|
||||||
|
|
|
@ -97,7 +97,7 @@ public class TrieDateField extends TrieField implements DateValueFieldType {
|
||||||
@Override
|
@Override
|
||||||
public Object toNativeType(Object val) {
|
public Object toNativeType(Object val) {
|
||||||
if (val instanceof CharSequence) {
|
if (val instanceof CharSequence) {
|
||||||
return DateMathParser.parseMath(null, (String)val);
|
return DateMathParser.parseMath(null, val.toString());
|
||||||
}
|
}
|
||||||
return super.toNativeType(val);
|
return super.toNativeType(val);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ import java.util.Date;
|
||||||
|
|
||||||
import org.apache.lucene.index.IndexableField;
|
import org.apache.lucene.index.IndexableField;
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
|
import org.apache.solr.common.util.ByteArrayUtf8CharSequence;
|
||||||
import org.apache.solr.core.SolrConfig;
|
import org.apache.solr.core.SolrConfig;
|
||||||
import org.apache.solr.core.SolrResourceLoader;
|
import org.apache.solr.core.SolrResourceLoader;
|
||||||
|
|
||||||
|
@ -61,4 +62,12 @@ public class DateFieldTest extends SolrTestCaseJ4 {
|
||||||
assertEquals(820454699990L, ((Date) f.toObject( out )).getTime() );
|
assertEquals(820454699990L, ((Date) f.toObject( out )).getTime() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testToNativeType() {
|
||||||
|
FieldType ft = new TrieDateField();
|
||||||
|
ByteArrayUtf8CharSequence charSequence = new ByteArrayUtf8CharSequence("1995-12-31T23:59:59Z");
|
||||||
|
|
||||||
|
Date val = (Date) ft.toNativeType(charSequence);
|
||||||
|
assertEquals("1995-12-31T23:59:59Z", val.toInstant().toString());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue