mirror of https://github.com/apache/lucene.git
Merged revision(s) 1673647 from lucene/dev/branches/branch_5x:
SOLR-7376: Return raw XML or JSON ........ git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1673649 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
fd70dadf80
commit
63edfb11c6
|
@ -97,6 +97,10 @@ New Features
|
||||||
* SOLR-7372: Limit memory consumed by LRUCache with a new 'maxRamMB' config parameter.
|
* SOLR-7372: Limit memory consumed by LRUCache with a new 'maxRamMB' config parameter.
|
||||||
(yonik, shalin)
|
(yonik, shalin)
|
||||||
|
|
||||||
|
* SOLR-7376: Return raw XML or JSON (in the appropriate writer) using DocumentTransformers.
|
||||||
|
?fl=id,name,json_s:[json],xml_s:[xml] (ryan)
|
||||||
|
|
||||||
|
|
||||||
Bug Fixes
|
Bug Fixes
|
||||||
----------------------
|
----------------------
|
||||||
|
|
||||||
|
|
|
@ -203,6 +203,8 @@ public abstract class TextResponseWriter {
|
||||||
writeByteArr(name, arr.bytes, arr.offset, arr.length);
|
writeByteArr(name, arr.bytes, arr.offset, arr.length);
|
||||||
} else if (val instanceof EnumFieldValue) {
|
} else if (val instanceof EnumFieldValue) {
|
||||||
writeStr(name, val.toString(), true);
|
writeStr(name, val.toString(), true);
|
||||||
|
} else if (val instanceof WriteableValue) {
|
||||||
|
((WriteableValue)val).write(name, this);
|
||||||
} else {
|
} else {
|
||||||
// default... for debugging only
|
// default... for debugging only
|
||||||
writeStr(name, val.getClass().getName() + ':' + val.toString(), true);
|
writeStr(name, val.getClass().getName() + ':' + val.toString(), true);
|
||||||
|
|
|
@ -48,5 +48,7 @@ public abstract class TransformerFactory implements NamedListInitializedPlugin
|
||||||
defaultFactories.put( "docid", new DocIdAugmenterFactory() );
|
defaultFactories.put( "docid", new DocIdAugmenterFactory() );
|
||||||
defaultFactories.put( "shard", new ShardAugmenterFactory() );
|
defaultFactories.put( "shard", new ShardAugmenterFactory() );
|
||||||
defaultFactories.put( "child", new ChildDocTransformerFactory() );
|
defaultFactories.put( "child", new ChildDocTransformerFactory() );
|
||||||
|
defaultFactories.put( "json", new RawValueTransformerFactory("json") );
|
||||||
|
defaultFactories.put( "xml", new RawValueTransformerFactory("xml") );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.apache.lucene.queries.function.ValueSource;
|
||||||
import org.apache.lucene.queries.function.valuesource.QueryValueSource;
|
import org.apache.lucene.queries.function.valuesource.QueryValueSource;
|
||||||
import org.apache.lucene.search.Query;
|
import org.apache.lucene.search.Query;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
import org.apache.solr.common.SolrException.ErrorCode;
|
||||||
import org.apache.solr.common.params.CommonParams;
|
import org.apache.solr.common.params.CommonParams;
|
||||||
import org.apache.solr.common.params.MapSolrParams;
|
import org.apache.solr.common.params.MapSolrParams;
|
||||||
import org.apache.solr.common.params.SolrParams;
|
import org.apache.solr.common.params.SolrParams;
|
||||||
|
@ -261,10 +262,13 @@ public class SolrReturnFields extends ReturnFields {
|
||||||
TransformerFactory factory = req.getCore().getTransformerFactory( augmenterName );
|
TransformerFactory factory = req.getCore().getTransformerFactory( augmenterName );
|
||||||
if( factory != null ) {
|
if( factory != null ) {
|
||||||
MapSolrParams augmenterParams = new MapSolrParams( augmenterArgs );
|
MapSolrParams augmenterParams = new MapSolrParams( augmenterArgs );
|
||||||
augmenters.addTransformer( factory.create(disp, augmenterParams, req) );
|
DocTransformer t = factory.create(disp, augmenterParams, req);
|
||||||
|
if(t!=null) {
|
||||||
|
augmenters.addTransformer( t );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// unknown transformer?
|
//throw new SolrException(ErrorCode.BAD_REQUEST, "Unknown DocTransformer: "+augmenterName);
|
||||||
}
|
}
|
||||||
addField(field, disp, augmenters, true);
|
addField(field, disp, augmenters, true);
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -95,6 +95,10 @@ public class JavaBinCodec {
|
||||||
this.stringCache = stringCache;
|
this.stringCache = stringCache;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ObjectResolver getResolver() {
|
||||||
|
return resolver;
|
||||||
|
}
|
||||||
|
|
||||||
public void marshal(Object nl, OutputStream os) throws IOException {
|
public void marshal(Object nl, OutputStream os) throws IOException {
|
||||||
init(FastOutputStream.wrap(os));
|
init(FastOutputStream.wrap(os));
|
||||||
try {
|
try {
|
||||||
|
@ -159,9 +163,15 @@ public class JavaBinCodec {
|
||||||
if (writeKnownType(val)) {
|
if (writeKnownType(val)) {
|
||||||
return;
|
return;
|
||||||
} else {
|
} else {
|
||||||
Object tmpVal = val;
|
ObjectResolver resolver = null;
|
||||||
|
if(val instanceof ObjectResolver) {
|
||||||
|
resolver = (ObjectResolver)val;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
resolver = this.resolver;
|
||||||
|
}
|
||||||
if (resolver != null) {
|
if (resolver != null) {
|
||||||
tmpVal = resolver.resolve(val, this);
|
Object tmpVal = resolver.resolve(val, this);
|
||||||
if (tmpVal == null) return; // null means the resolver took care of it fully
|
if (tmpVal == null) return; // null means the resolver took care of it fully
|
||||||
if (writeKnownType(tmpVal)) return;
|
if (writeKnownType(tmpVal)) return;
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,13 +19,17 @@ package org.apache.solr.client.solrj;
|
||||||
|
|
||||||
|
|
||||||
import com.google.common.collect.Maps;
|
import com.google.common.collect.Maps;
|
||||||
|
|
||||||
import junit.framework.Assert;
|
import junit.framework.Assert;
|
||||||
|
|
||||||
import org.apache.lucene.util.TestUtil;
|
import org.apache.lucene.util.TestUtil;
|
||||||
import org.apache.solr.SolrTestCaseJ4.SuppressSSL;
|
import org.apache.solr.SolrTestCaseJ4.SuppressSSL;
|
||||||
import org.apache.solr.client.solrj.embedded.EmbeddedSolrServer;
|
import org.apache.solr.client.solrj.embedded.EmbeddedSolrServer;
|
||||||
import org.apache.solr.client.solrj.impl.BinaryResponseParser;
|
import org.apache.solr.client.solrj.impl.BinaryResponseParser;
|
||||||
import org.apache.solr.client.solrj.impl.ConcurrentUpdateSolrClient;
|
import org.apache.solr.client.solrj.impl.ConcurrentUpdateSolrClient;
|
||||||
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
||||||
|
import org.apache.solr.client.solrj.impl.HttpSolrClient.RemoteSolrException;
|
||||||
|
import org.apache.solr.client.solrj.impl.NoOpResponseParser;
|
||||||
import org.apache.solr.client.solrj.impl.XMLResponseParser;
|
import org.apache.solr.client.solrj.impl.XMLResponseParser;
|
||||||
import org.apache.solr.client.solrj.request.AbstractUpdateRequest;
|
import org.apache.solr.client.solrj.request.AbstractUpdateRequest;
|
||||||
import org.apache.solr.client.solrj.request.AbstractUpdateRequest.ACTION;
|
import org.apache.solr.client.solrj.request.AbstractUpdateRequest.ACTION;
|
||||||
|
@ -42,6 +46,7 @@ import org.apache.solr.client.solrj.response.UpdateResponse;
|
||||||
import org.apache.solr.common.SolrDocument;
|
import org.apache.solr.common.SolrDocument;
|
||||||
import org.apache.solr.common.SolrDocumentList;
|
import org.apache.solr.common.SolrDocumentList;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
import org.apache.solr.common.SolrException.ErrorCode;
|
||||||
import org.apache.solr.common.SolrInputDocument;
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
import org.apache.solr.common.params.AnalysisParams;
|
import org.apache.solr.common.params.AnalysisParams;
|
||||||
import org.apache.solr.common.params.CommonParams;
|
import org.apache.solr.common.params.CommonParams;
|
||||||
|
@ -49,6 +54,7 @@ import org.apache.solr.common.params.FacetParams;
|
||||||
import org.apache.solr.common.params.ModifiableSolrParams;
|
import org.apache.solr.common.params.ModifiableSolrParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
import org.noggit.JSONParser;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
@ -521,6 +527,89 @@ abstract public class SolrExampleTests extends SolrExampleTestsBase
|
||||||
assertEquals( "aaa", out1.get( "aaa" ) );
|
assertEquals( "aaa", out1.get( "aaa" ) );
|
||||||
assertEquals( 10, ((Integer)out1.get( "ten" )).intValue() );
|
assertEquals( 10, ((Integer)out1.get( "ten" )).intValue() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testRawFields() throws Exception
|
||||||
|
{
|
||||||
|
String rawJson = "{ \"raw\": 1.234, \"id\":\"111\" }";
|
||||||
|
String rawXml = "<hello>this is <some/><xml/></hello>";
|
||||||
|
SolrClient client = getSolrClient();
|
||||||
|
|
||||||
|
// Empty the database...
|
||||||
|
client.deleteByQuery("*:*");// delete everything!
|
||||||
|
|
||||||
|
// Now add something...
|
||||||
|
SolrInputDocument doc = new SolrInputDocument();
|
||||||
|
doc.addField( "id", "111", 1.0f );
|
||||||
|
doc.addField( "name", "doc1", 1.0f );
|
||||||
|
doc.addField( "json_s", rawJson );
|
||||||
|
doc.addField( "xml_s", rawXml );
|
||||||
|
client.add(doc);
|
||||||
|
client.commit(); // make sure this gets in first
|
||||||
|
|
||||||
|
SolrQuery query = new SolrQuery();
|
||||||
|
query.setQuery( "*:*" );
|
||||||
|
query.set( CommonParams.FL, "id,json_s:[json],xml_s:[xml]" );
|
||||||
|
|
||||||
|
QueryRequest req = new QueryRequest( query );
|
||||||
|
req.setResponseParser(new BinaryResponseParser());
|
||||||
|
QueryResponse rsp = req.process(client);
|
||||||
|
|
||||||
|
SolrDocumentList out = rsp.getResults();
|
||||||
|
assertEquals( 1, out.getNumFound() );
|
||||||
|
SolrDocument out1 = out.get( 0 );
|
||||||
|
assertEquals( "111", out1.getFieldValue( "id" ) );
|
||||||
|
|
||||||
|
// Check that the 'raw' fields are unchanged using the standard formats
|
||||||
|
assertEquals( rawJson, out1.get( "json_s" ) );
|
||||||
|
assertEquals( rawXml, out1.get( "xml_s" ) );
|
||||||
|
|
||||||
|
// // Check that unknown augmenters throw an error
|
||||||
|
// query.set( CommonParams.FL, "id,[asdkgjahsdgjka]" );
|
||||||
|
// try {
|
||||||
|
// rsp = client.query( query );
|
||||||
|
// fail("Should throw an exception for unknown transformer: "+query.get(CommonParams.FL));
|
||||||
|
// }
|
||||||
|
// catch(SolrException ex) {
|
||||||
|
// assertEquals(ErrorCode.BAD_REQUEST.code, ex.code());
|
||||||
|
// }
|
||||||
|
|
||||||
|
if(client instanceof EmbeddedSolrServer) {
|
||||||
|
return; // the EmbeddedSolrServer ignores the configured parser
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check raw JSON Output
|
||||||
|
query.set("fl", "id,json_s:[json],xml_s:[xml]");
|
||||||
|
query.set(CommonParams.WT, "json");
|
||||||
|
|
||||||
|
req = new QueryRequest( query );
|
||||||
|
req.setResponseParser(new NoOpResponseParser("json"));
|
||||||
|
NamedList<Object> resp = client.request(req);
|
||||||
|
String raw = (String)resp.get("response");
|
||||||
|
|
||||||
|
// Check that the response parses as JSON
|
||||||
|
JSONParser parser = new JSONParser(raw);
|
||||||
|
int evt = parser.nextEvent();
|
||||||
|
while(evt!=JSONParser.EOF) {
|
||||||
|
evt = parser.nextEvent();
|
||||||
|
}
|
||||||
|
assertTrue(raw.indexOf(rawJson)>0); // no escaping
|
||||||
|
assertTrue(raw.indexOf('"'+rawXml+'"')>0); // quoted xml
|
||||||
|
|
||||||
|
// Check raw XML Output
|
||||||
|
req.setResponseParser(new NoOpResponseParser("xml"));
|
||||||
|
query.set("fl", "id,json_s:[json],xml_s:[xml]");
|
||||||
|
query.set(CommonParams.WT, "xml");
|
||||||
|
req = new QueryRequest( query );
|
||||||
|
req.setResponseParser(new NoOpResponseParser("xml"));
|
||||||
|
resp = client.request(req);
|
||||||
|
raw = (String)resp.get("response");
|
||||||
|
|
||||||
|
// Check that we get raw xml and json is escaped
|
||||||
|
assertTrue(raw.indexOf('>'+rawJson+'<')>0); // escaped
|
||||||
|
assertTrue(raw.indexOf(rawXml)>0); // raw xml
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testUpdateRequestWithParameters() throws Exception {
|
public void testUpdateRequestWithParameters() throws Exception {
|
||||||
|
@ -1781,4 +1870,4 @@ abstract public class SolrExampleTests extends SolrExampleTestsBase
|
||||||
}
|
}
|
||||||
return sdoc;
|
return sdoc;
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue