SOLR-6770 Added testcase for standalone mode and fixed a reload bug

git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1649551 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Noble Paul 2015-01-05 15:44:57 +00:00
parent 5a86451cba
commit de4f26978f
3 changed files with 215 additions and 9 deletions

View File

@ -135,9 +135,9 @@ public class RequestParams implements MapSerializable{
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, e); throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, e);
} }
} else if(requestParams == null) { } else {
Object[] o = getMapAndVersion(loader, RequestParams.RESOURCE); Object[] o = getMapAndVersion(loader, RequestParams.RESOURCE);
requestParams = new RequestParams((Map) o[0],(Integer)o[1]); requestParams = new RequestParams((Map) o[0], (Integer) o[1]);
} }
return requestParams; return requestParams;

View File

@ -829,10 +829,10 @@ public class SolrResourceLoader implements ResourceLoader,Closeable
public static void persistConfLocally(SolrResourceLoader loader, String resourceName, byte[] content) { public static void persistConfLocally(SolrResourceLoader loader, String resourceName, byte[] content) {
// Persist locally // Persist locally
File managedSchemaFile = new File(loader.getConfigDir(), resourceName); File confFile = new File(loader.getConfigDir(), resourceName);
OutputStreamWriter writer = null; OutputStreamWriter writer = null;
try { try {
File parentDir = managedSchemaFile.getParentFile(); File parentDir = confFile.getParentFile();
if ( ! parentDir.isDirectory()) { if ( ! parentDir.isDirectory()) {
if ( ! parentDir.mkdirs()) { if ( ! parentDir.mkdirs()) {
final String msg = "Can't create managed schema directory " + parentDir.getAbsolutePath(); final String msg = "Can't create managed schema directory " + parentDir.getAbsolutePath();
@ -840,19 +840,19 @@ public class SolrResourceLoader implements ResourceLoader,Closeable
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, msg); throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, msg);
} }
} }
final FileOutputStream out = new FileOutputStream(managedSchemaFile); final FileOutputStream out = new FileOutputStream(confFile);
out.write(content); out.write(content);
log.info("Upgraded to managed schema at " + managedSchemaFile.getPath()); log.info("Written confile " + resourceName);
} catch (IOException e) { } catch (IOException e) {
final String msg = "Error persisting managed schema " + managedSchemaFile; final String msg = "Error persisting conf file " + resourceName;
log.error(msg, e); log.error(msg, e);
throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, msg, e); throw new SolrException(SolrException.ErrorCode.SERVER_ERROR, msg, e);
} finally { } finally {
org.apache.commons.io.IOUtils.closeQuietly(writer); org.apache.commons.io.IOUtils.closeQuietly(writer);
try { try {
FileUtils.sync(managedSchemaFile); FileUtils.sync(confFile);
} catch (IOException e) { } catch (IOException e) {
final String msg = "Error syncing the managed schema file " + managedSchemaFile; final String msg = "Error syncing conf file " + resourceName;
log.error(msg, e); log.error(msg, e);
} }
} }

View File

@ -23,6 +23,7 @@ import java.io.IOException;
import java.io.StringReader; import java.io.StringReader;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.text.MessageFormat; import java.text.MessageFormat;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.List; import java.util.List;
@ -36,6 +37,9 @@ import com.google.common.collect.ImmutableList;
import org.apache.commons.io.FileUtils; import org.apache.commons.io.FileUtils;
import org.apache.solr.SolrTestCaseJ4; import org.apache.solr.SolrTestCaseJ4;
import org.apache.solr.client.solrj.impl.CloudSolrClient; import org.apache.solr.client.solrj.impl.CloudSolrClient;
import org.apache.solr.common.cloud.DocCollection;
import org.apache.solr.common.cloud.Replica;
import org.apache.solr.common.cloud.Slice;
import org.apache.solr.common.cloud.ZkStateReader; import org.apache.solr.common.cloud.ZkStateReader;
import org.apache.solr.handler.TestSolrConfigHandlerConcurrent; import org.apache.solr.handler.TestSolrConfigHandlerConcurrent;
import org.apache.solr.util.RestTestBase; import org.apache.solr.util.RestTestBase;
@ -231,6 +235,208 @@ public class TestSolrConfigHandler extends RestTestBase {
assertTrue(MessageFormat.format("Could not get expected value {0} for path {1} full output {2}", expected, jsonPath, new String(ZkStateReader.toJSON(m), StandardCharsets.UTF_8)), success); assertTrue(MessageFormat.format("Could not get expected value {0} for path {1} full output {2}", expected, jsonPath, new String(ZkStateReader.toJSON(m), StandardCharsets.UTF_8)), success);
} }
public void testReqParams() throws Exception{
RestTestHarness harness = restTestHarness;
String payload = " {\n" +
" 'set' : {'x': {" +
" 'a':'A val',\n" +
" 'b': 'B val'}\n" +
" }\n" +
" }";
TestSolrConfigHandler.runConfigCommand(harness,"/config/params?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "x", "a"),
"A val",
10);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "x", "b"),
"B val",
10);
payload = "{\n" +
"'create-requesthandler' : { 'name' : '/dump', 'class': 'org.apache.solr.handler.DumpRequestHandler' }\n" +
"}";
TestSolrConfigHandler.runConfigCommand(harness, "/config?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/overlay?wt=json",
null,
Arrays.asList("overlay", "requestHandler", "/dump", "name"),
"/dump",
10);
TestSolrConfigHandler.testForResponseElement(harness,
null,
"/dump?wt=json&useParams=x",
null,
Arrays.asList("params", "a"),
"A val",
5);
TestSolrConfigHandler.testForResponseElement(harness,
null,
"/dump?wt=json&useParams=x&a=fomrequest",
null,
Arrays.asList("params", "a"),
"fomrequest",
5);
payload = "{\n" +
"'create-requesthandler' : { 'name' : '/dump1', 'class': 'org.apache.solr.handler.DumpRequestHandler', 'useParams':'x' }\n" +
"}";
TestSolrConfigHandler.runConfigCommand(harness,"/config?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(harness,
null,
"/config/overlay?wt=json",
null,
Arrays.asList("overlay", "requestHandler", "/dump1", "name"),
"/dump1",
10);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/dump1?wt=json",
null,
Arrays.asList("params", "a"),
"A val",
5);
payload = " {\n" +
" 'set' : {'y':{\n" +
" 'c':'CY val',\n" +
" 'b': 'BY val'}\n" +
" }\n" +
" }";
TestSolrConfigHandler.runConfigCommand(harness,"/config/params?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "y", "c"),
"CY val",
10);
TestSolrConfigHandler.testForResponseElement(harness,
null,
"/dump?wt=json&useParams=y",
null,
Arrays.asList("params", "c"),
"CY val",
5);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/dump1?wt=json&useParams=y",
null,
Arrays.asList("params", "b"),
"BY val",
5);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/dump1?wt=json&useParams=y",
null,
Arrays.asList("params", "a"),
null,
5);
payload = " {\n" +
" 'update' : {'y': {\n" +
" 'c':'CY val modified',\n" +
" 'e':'EY val',\n" +
" 'b': 'BY val'" +
"}\n" +
" }\n" +
" }";
TestSolrConfigHandler.runConfigCommand(harness,"/config/params?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "y", "c"),
"CY val modified",
10);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "y", "e"),
"EY val",
10);
payload = " {\n" +
" 'set' : {'y': {\n" +
" 'p':'P val',\n" +
" 'q': 'Q val'" +
"}\n" +
" }\n" +
" }";
TestSolrConfigHandler.runConfigCommand(harness,"/config/params?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "y", "p"),
"P val",
10);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "y", "c"),
null,
10);
payload = " {'delete' : 'y'}";
TestSolrConfigHandler.runConfigCommand(harness,"/config/params?wt=json", payload);
TestSolrConfigHandler.testForResponseElement(
harness,
null,
"/config/params?wt=json",
null,
Arrays.asList("response", "params", "y", "p"),
null,
10);
}
public static Map getRespMap(String path, RestTestHarness restHarness) throws Exception { public static Map getRespMap(String path, RestTestHarness restHarness) throws Exception {
String response = restHarness.query(path); String response = restHarness.query(path);