mirror of https://github.com/apache/lucene.git
SOLR-9234: srcField parameter works only when all fields are captured in the /update/json/docs endpoint
This commit is contained in:
parent
3a9019e020
commit
73d5f1c52c
|
@ -47,6 +47,9 @@ Bug Fixes
|
||||||
* SOLR-9161: Change SolrPluginUtils.invokeSetters implementation to accommodate setter variants.
|
* SOLR-9161: Change SolrPluginUtils.invokeSetters implementation to accommodate setter variants.
|
||||||
(Christine Poerschke, Steve Rowe, Uwe Schindler)
|
(Christine Poerschke, Steve Rowe, Uwe Schindler)
|
||||||
|
|
||||||
|
* SOLR-9234: srcField parameter works only when all fields are captured in the /update/json/docs
|
||||||
|
endpoint (noble)
|
||||||
|
|
||||||
Other Changes
|
Other Changes
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -22,56 +22,73 @@ import java.io.Reader;
|
||||||
import org.noggit.CharArr;
|
import org.noggit.CharArr;
|
||||||
import org.noggit.JSONParser;
|
import org.noggit.JSONParser;
|
||||||
|
|
||||||
public class RecordingJSONParser extends JSONParser{
|
public class RecordingJSONParser extends JSONParser {
|
||||||
public RecordingJSONParser(Reader in) { super(in); }
|
static ThreadLocal<char[]> buf = new ThreadLocal<>();
|
||||||
|
private final char[] bufCopy;
|
||||||
|
//global position is the global position at the beginning of my buffer
|
||||||
|
private long globalPosition = 0;
|
||||||
|
|
||||||
private StringBuilder sb = new StringBuilder() ;
|
private StringBuilder sb = new StringBuilder();
|
||||||
private long position;
|
private boolean objectStarted = false;
|
||||||
private boolean objectStarted =false;
|
public long lastMarkedPosition = 0;
|
||||||
|
|
||||||
|
|
||||||
|
public RecordingJSONParser(Reader in) {
|
||||||
|
super(in, getChars());
|
||||||
|
bufCopy = buf.get();
|
||||||
|
buf.remove();
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
static char[] getChars() {
|
||||||
protected int getChar() throws IOException {
|
buf.set(new char[8192]);
|
||||||
int aChar = super.getChar();
|
return buf.get();
|
||||||
if(aChar == '{') objectStarted =true;
|
|
||||||
if(getPosition() >position) recordChar((char) aChar); // check before adding if a pushback happened ignore
|
|
||||||
position= getPosition();
|
|
||||||
return aChar;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void recordChar(int aChar) {
|
private void recordChar(int aChar) {
|
||||||
if(objectStarted)
|
if (objectStarted) {
|
||||||
sb.append((char) aChar);
|
sb.append((char) aChar);
|
||||||
|
} else if (aChar == '{') {
|
||||||
|
sb.append((char) aChar);
|
||||||
|
objectStarted = true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
private void recordStr(String s) {
|
|
||||||
if(objectStarted) sb.append(s);
|
public void resetBuf() {
|
||||||
|
sb = new StringBuilder();
|
||||||
|
objectStarted = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public CharArr getStringChars() throws IOException {
|
public int nextEvent() throws IOException {
|
||||||
CharArr chars = super.getStringChars();
|
captureMissing();
|
||||||
recordStr(chars.toString());
|
return super.nextEvent();
|
||||||
position = getPosition();
|
}
|
||||||
// if reading a String , the getStringChars do not return the closing single quote or double quote
|
|
||||||
//so, try to capture that
|
private void captureMissing() {
|
||||||
if(chars.getArray().length >chars.getStart()+chars.size()) {
|
long currPosition = getPosition() - globalPosition;
|
||||||
char next = chars.getArray()[chars.getStart() + chars.size()];
|
if(currPosition < 0){
|
||||||
if(next =='"' || next == '\'') {
|
System.out.println("ERROR");
|
||||||
recordChar(next);
|
}
|
||||||
|
if (currPosition > lastMarkedPosition) {
|
||||||
|
for (long i = lastMarkedPosition; i < currPosition; i++) {
|
||||||
|
recordChar(bufCopy[(int) i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return chars;
|
lastMarkedPosition = currPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void resetBuf(){
|
|
||||||
sb = new StringBuilder();
|
|
||||||
objectStarted=false;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void fill() throws IOException {
|
||||||
|
captureMissing();
|
||||||
|
super.fill();
|
||||||
|
this.globalPosition = getPosition();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public String getBuf() {
|
public String getBuf() {
|
||||||
if(sb != null) return sb.toString();
|
captureMissing();
|
||||||
|
if (sb != null) return sb.toString();
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -18,9 +18,12 @@ package org.apache.solr.common.util;
|
||||||
|
|
||||||
import org.apache.solr.SolrTestCaseJ4;
|
import org.apache.solr.SolrTestCaseJ4;
|
||||||
import org.apache.solr.util.RecordingJSONParser;
|
import org.apache.solr.util.RecordingJSONParser;
|
||||||
|
import org.slf4j.Logger;
|
||||||
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.StringReader;
|
import java.io.StringReader;
|
||||||
|
import java.lang.invoke.MethodHandles;
|
||||||
import java.lang.ref.WeakReference;
|
import java.lang.ref.WeakReference;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -30,6 +33,8 @@ import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
|
|
||||||
public class TestJsonRecordReader extends SolrTestCaseJ4 {
|
public class TestJsonRecordReader extends SolrTestCaseJ4 {
|
||||||
|
private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
|
||||||
|
|
||||||
public void testOneLevelSplit() throws IOException {
|
public void testOneLevelSplit() throws IOException {
|
||||||
String json = "{\n" +
|
String json = "{\n" +
|
||||||
" \"a\":\"A\" ,\n" +
|
" \"a\":\"A\" ,\n" +
|
||||||
|
@ -115,6 +120,53 @@ public class TestJsonRecordReader extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testSrcField() throws Exception {
|
||||||
|
String json = "{\n" +
|
||||||
|
" \"id\" : \"123\",\n" +
|
||||||
|
" \"description\": \"Testing /json/docs srcField 1\",\n" +
|
||||||
|
"\n" +
|
||||||
|
" \"nested_data\" : {\n" +
|
||||||
|
" \"nested_inside\" : \"check check check 1\"\n" +
|
||||||
|
" }\n" +
|
||||||
|
"}";
|
||||||
|
String json2 =
|
||||||
|
" {\n" +
|
||||||
|
" \"id\" : \"345\",\n" +
|
||||||
|
" \"description\": \"Testing /json/docs srcField 2\",\n" +
|
||||||
|
"\n" +
|
||||||
|
" \"nested_data\" : {\n" +
|
||||||
|
" \"nested_inside\" : \"check check check 2\"\n" +
|
||||||
|
" }\n" +
|
||||||
|
"}";
|
||||||
|
JsonRecordReader streamer = JsonRecordReader.getInst("/", Arrays.asList("id:/id"));
|
||||||
|
RecordingJSONParser parser = new RecordingJSONParser(new StringReader(json + json2));
|
||||||
|
|
||||||
|
|
||||||
|
streamer.streamRecords(parser, new JsonRecordReader.Handler() {
|
||||||
|
int count = 0;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void handle(Map<String, Object> record, String path) {
|
||||||
|
count++;
|
||||||
|
String buf = parser.getBuf();
|
||||||
|
parser.resetBuf();
|
||||||
|
|
||||||
|
Map m = (Map) Utils.fromJSONString(buf);
|
||||||
|
if (count == 1) {
|
||||||
|
assertEquals(m.get("id"), "123");
|
||||||
|
assertEquals(m.get("description"), "Testing /json/docs srcField 1");
|
||||||
|
assertEquals(((Map) m.get("nested_data")).get("nested_inside"), "check check check 1");
|
||||||
|
}
|
||||||
|
if (count++ == 2) {
|
||||||
|
assertEquals(m.get("id"), "345");
|
||||||
|
assertEquals(m.get("description"), "Testing /json/docs srcField 2");
|
||||||
|
assertEquals(((Map) m.get("nested_data")).get("nested_inside"), "check check check 2");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
public void testRecursiveWildCard() throws IOException {
|
public void testRecursiveWildCard() throws IOException {
|
||||||
String json = "{\n" +
|
String json = "{\n" +
|
||||||
" \"a\":\"A\" ,\n" +
|
" \"a\":\"A\" ,\n" +
|
||||||
|
|
Loading…
Reference in New Issue