/* * 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.search; import java.io.IOException; import java.io.InputStream; import java.util.Map; import org.apache.solr.JSONTestUtil; import org.apache.solr.SolrTestCaseHS; import org.apache.solr.SolrTestCaseJ4; import org.apache.solr.client.solrj.SolrClient; import org.apache.solr.client.solrj.impl.BinaryResponseParser; import org.apache.solr.client.solrj.impl.HttpSolrClient; import org.apache.solr.client.solrj.request.QueryRequest; import org.apache.solr.common.params.SolrParams; import org.apache.solr.common.util.NamedList; import org.apache.solr.common.util.Utils; import org.apache.solr.response.SmileWriterTest; import org.apache.solr.search.json.TestJsonRequest; import org.junit.AfterClass; import org.junit.BeforeClass; import org.junit.Test; @SolrTestCaseJ4.SuppressSSL public class TestSmileRequest extends SolrTestCaseJ4 { private static SolrTestCaseHS.SolrInstances servers; // for distributed testing @BeforeClass public static void beforeTests() throws Exception { JSONTestUtil.failRepeatedKeys = true; initCore("solrconfig-tlog.xml", "schema_latest.xml"); } public static void initServers() throws Exception { if (servers == null) { servers = new SolrTestCaseHS.SolrInstances(3, "solrconfig-tlog.xml", "schema_latest.xml"); } } @AfterClass public static void afterTests() throws Exception { JSONTestUtil.failRepeatedKeys = false; if (servers != null) { servers.stop(); servers = null; } } @Test public void testDistribJsonRequest() throws Exception { initServers(); SolrTestCaseHS.Client client = servers.getClient(random().nextInt()); client.tester = new SolrTestCaseHS.Client.Tester() { @Override public void assertJQ(SolrClient client, SolrParams args, String... tests) throws Exception { ((HttpSolrClient) client).setParser(SmileResponseParser.inst); QueryRequest query = new QueryRequest(args); String path = args.get("qt"); if (path != null) { query.setPath(path); } NamedList<Object> rsp = client.request(query); Map m = rsp.asMap(5); String jsonStr = Utils.toJSONString(m); SolrTestCaseHS.matchJSON(jsonStr, tests); } }; client.queryDefaults().set("shards", servers.getShards()); TestJsonRequest.doJsonRequest(client); } //adding this to core adds the dependency on a few extra jars to our distribution. // So this is not added there public static class SmileResponseParser extends BinaryResponseParser { public static final SmileResponseParser inst = new SmileResponseParser(); @Override public String getWriterType() { return "smile"; } @Override public NamedList<Object> processResponse(InputStream body, String encoding) { try { Map m = (Map) SmileWriterTest.decodeSmile(body); return new NamedList(m); } catch (IOException e) { throw new RuntimeException(e); } } } }