/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.solr.response; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.util.Locale; import java.util.Map; import java.util.UUID; import org.apache.solr.common.SolrDocument; import org.apache.solr.common.SolrDocumentList; import org.apache.solr.common.params.CommonParams; import org.apache.solr.common.util.JavaBinCodec; import org.apache.solr.common.util.NamedList; import org.apache.solr.request.LocalSolrQueryRequest; import org.apache.solr.response.BinaryResponseWriter.Resolver; import org.apache.solr.search.SolrReturnFields; import org.apache.solr.util.AbstractSolrTestCase; import org.junit.BeforeClass; /** * Test for BinaryResponseWriter * * * @since solr 1.4 */ public class TestBinaryResponseWriter extends AbstractSolrTestCase { @BeforeClass public static void beforeClass() throws Exception { System.setProperty("enable.update.log", "false"); // schema12 doesn't support _version_ initCore("solrconfig.xml", "schema12.xml"); } /** * Tests known types implementation by asserting correct encoding/decoding of UUIDField */ public void testUUID() throws Exception { String s = UUID.randomUUID().toString().toLowerCase(Locale.ROOT); assertU(adoc("id", "101", "uuid", s)); assertU(commit()); LocalSolrQueryRequest req = lrf.makeRequest("q", "*:*"); SolrQueryResponse rsp = h.queryAndResponse(req.getParams().get(CommonParams.QT), req); BinaryQueryResponseWriter writer = (BinaryQueryResponseWriter) h.getCore().getQueryResponseWriter("javabin"); ByteArrayOutputStream baos = new ByteArrayOutputStream(); writer.write(baos, req, rsp); NamedList res = (NamedList) new JavaBinCodec().unmarshal(new ByteArrayInputStream(baos.toByteArray())); SolrDocumentList docs = (SolrDocumentList) res.get("response"); for (Object doc : docs) { SolrDocument document = (SolrDocument) doc; assertEquals("Returned object must be a string", "java.lang.String", document.getFieldValue("uuid").getClass().getName()); assertEquals("Wrong UUID string returned", s, document.getFieldValue("uuid")); } req.close(); } public void testResolverSolrDocumentPartialFields() throws Exception { LocalSolrQueryRequest req = lrf.makeRequest("q", "*:*", "fl", "id,xxx,ddd_s"); SolrDocument in = new SolrDocument(); in.addField("id", 345); in.addField("aaa_s", "aaa"); in.addField("bbb_s", "bbb"); in.addField("ccc_s", "ccc"); in.addField("ddd_s", "ddd"); in.addField("eee_s", "eee"); Resolver r = new Resolver(req, new SolrReturnFields(req)); Object o = r.resolve(in, new JavaBinCodec()); assertNotNull("obj is null", o); assertTrue("obj is not doc", o instanceof SolrDocument); SolrDocument out = new SolrDocument(); for (Map.Entry<String, Object> e : in) { if(r.isWritable(e.getKey())) out.put(e.getKey(),e.getValue()); } assertTrue("id not found", out.getFieldNames().contains("id")); assertTrue("ddd_s not found", out.getFieldNames().contains("ddd_s")); assertEquals("Wrong number of fields found", 2, out.getFieldNames().size()); req.close(); } }