mirror of https://github.com/apache/lucene.git
SOLR-6787 hardening tests
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1650030 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
941f6e64c8
commit
3b988de804
|
@ -41,6 +41,7 @@ import org.apache.solr.common.cloud.DocCollection;
|
||||||
import org.apache.solr.common.cloud.Replica;
|
import org.apache.solr.common.cloud.Replica;
|
||||||
import org.apache.solr.common.cloud.Slice;
|
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.TestBlobHandler;
|
||||||
import org.apache.solr.handler.TestSolrConfigHandlerConcurrent;
|
import org.apache.solr.handler.TestSolrConfigHandlerConcurrent;
|
||||||
import org.apache.solr.util.RestTestBase;
|
import org.apache.solr.util.RestTestBase;
|
||||||
import org.apache.solr.util.RestTestHarness;
|
import org.apache.solr.util.RestTestHarness;
|
||||||
|
@ -54,6 +55,7 @@ import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import static org.apache.solr.core.ConfigOverlay.getObjectByPath;
|
import static org.apache.solr.core.ConfigOverlay.getObjectByPath;
|
||||||
|
import static org.apache.solr.handler.TestBlobHandler.getAsString;
|
||||||
|
|
||||||
public class TestSolrConfigHandler extends RestTestBase {
|
public class TestSolrConfigHandler extends RestTestBase {
|
||||||
public static final Logger log = LoggerFactory.getLogger(TestSolrConfigHandler.class);
|
public static final Logger log = LoggerFactory.getLogger(TestSolrConfigHandler.class);
|
||||||
|
@ -251,7 +253,7 @@ 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, getAsString(m)), success);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testReqParams() throws Exception{
|
public void testReqParams() throws Exception{
|
||||||
|
|
|
@ -37,13 +37,17 @@ import org.apache.solr.common.cloud.ZkStateReader;
|
||||||
import org.apache.solr.core.ConfigOverlay;
|
import org.apache.solr.core.ConfigOverlay;
|
||||||
import org.apache.solr.update.DirectUpdateHandler2;
|
import org.apache.solr.update.DirectUpdateHandler2;
|
||||||
import org.apache.solr.util.SimplePostTool;
|
import org.apache.solr.util.SimplePostTool;
|
||||||
|
import org.noggit.JSONParser;
|
||||||
|
import org.noggit.ObjectBuilder;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.io.StringReader;
|
||||||
import java.nio.ByteBuffer;
|
import java.nio.ByteBuffer;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.concurrent.TimeUnit;
|
import java.util.concurrent.TimeUnit;
|
||||||
|
@ -88,7 +92,7 @@ public class TestBlobHandler extends AbstractFullDistribZkTestBase {
|
||||||
map = TestSolrConfigHandlerConcurrent.getAsMap(url,cloudClient);
|
map = TestSolrConfigHandlerConcurrent.getAsMap(url,cloudClient);
|
||||||
List l = (List) ConfigOverlay.getObjectByPath(map, false, Arrays.asList("response", "docs"));
|
List l = (List) ConfigOverlay.getObjectByPath(map, false, Arrays.asList("response", "docs"));
|
||||||
assertNotNull(""+map, l);
|
assertNotNull(""+map, l);
|
||||||
assertTrue(""+map, l.size()>0);
|
assertTrue("" + map, l.size() > 0);
|
||||||
map = (Map) l.get(0);
|
map = (Map) l.get(0);
|
||||||
assertEquals(""+bytarr.length,String.valueOf(map.get("size")));
|
assertEquals(""+bytarr.length,String.valueOf(map.get("size")));
|
||||||
|
|
||||||
|
@ -120,27 +124,30 @@ public class TestBlobHandler extends AbstractFullDistribZkTestBase {
|
||||||
|
|
||||||
public static void postAndCheck(CloudSolrClient cloudClient, String baseUrl, ByteBuffer bytes, int count) throws Exception {
|
public static void postAndCheck(CloudSolrClient cloudClient, String baseUrl, ByteBuffer bytes, int count) throws Exception {
|
||||||
postData(cloudClient, baseUrl, bytes);
|
postData(cloudClient, baseUrl, bytes);
|
||||||
|
|
||||||
String url;
|
String url;
|
||||||
Map map;
|
Map map = null;
|
||||||
List l;
|
List l;
|
||||||
long startTime = System.nanoTime();
|
|
||||||
long maxTimeoutSeconds = 10;
|
for(int i=0;i<100;i++) {//10secs
|
||||||
while ( true) {
|
|
||||||
url = baseUrl + "/.system/blob/test";
|
url = baseUrl + "/.system/blob/test";
|
||||||
map = TestSolrConfigHandlerConcurrent.getAsMap(url, cloudClient);
|
map = TestSolrConfigHandlerConcurrent.getAsMap(url, cloudClient);
|
||||||
String numFound = String.valueOf(ConfigOverlay.getObjectByPath(map, false, Arrays.asList("response", "numFound")));
|
String numFound = String.valueOf(ConfigOverlay.getObjectByPath(map, false, Arrays.asList("response", "numFound")));
|
||||||
if(!(""+count).equals(numFound)) {
|
if(!(""+count).equals(numFound)) {
|
||||||
if (TimeUnit.SECONDS.convert(System.nanoTime() - startTime, TimeUnit.NANOSECONDS) < maxTimeoutSeconds) {
|
Thread.sleep(100);
|
||||||
Thread.sleep(100);
|
continue;
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
l = (List) ConfigOverlay.getObjectByPath(map, false, Arrays.asList("response", "docs"));
|
l = (List) ConfigOverlay.getObjectByPath(map, false, Arrays.asList("response", "docs"));
|
||||||
assertNotNull(l);
|
assertNotNull(l);
|
||||||
map = (Map) l.get(0);
|
map = (Map) l.get(0);
|
||||||
assertEquals("" + bytes.limit(), String.valueOf(map.get("size")));
|
assertEquals("" + bytes.limit(), String.valueOf(map.get("size")));
|
||||||
break;
|
return;
|
||||||
}
|
}
|
||||||
|
fail("Could not successfully add blob " + getAsString(map));
|
||||||
|
}
|
||||||
|
|
||||||
|
public static String getAsString(Map map) {
|
||||||
|
return new String(ZkStateReader.toJSON(map), StandardCharsets.UTF_8);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void compareInputAndOutput(String url, byte[] bytarr) throws IOException {
|
private void compareInputAndOutput(String url, byte[] bytarr) throws IOException {
|
||||||
|
@ -161,16 +168,23 @@ public class TestBlobHandler extends AbstractFullDistribZkTestBase {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static String postData(CloudSolrClient cloudClient, String baseUrl, ByteBuffer bytarr) throws IOException {
|
public static void postData(CloudSolrClient cloudClient, String baseUrl, ByteBuffer bytarr) throws IOException {
|
||||||
HttpPost httpPost = null;
|
HttpPost httpPost = null;
|
||||||
HttpEntity entity;
|
HttpEntity entity;
|
||||||
String response;
|
String response = null;
|
||||||
try {
|
try {
|
||||||
httpPost = new HttpPost(baseUrl+"/.system/blob/test");
|
httpPost = new HttpPost(baseUrl+"/.system/blob/test");
|
||||||
httpPost.setHeader("Content-Type","application/octet-stream");
|
httpPost.setHeader("Content-Type","application/octet-stream");
|
||||||
httpPost.setEntity(new ByteArrayEntity(bytarr.array(), bytarr.arrayOffset(), bytarr.limit()));
|
httpPost.setEntity(new ByteArrayEntity(bytarr.array(), bytarr.arrayOffset(), bytarr.limit()));
|
||||||
entity = cloudClient.getLbClient().getHttpClient().execute(httpPost).getEntity();
|
entity = cloudClient.getLbClient().getHttpClient().execute(httpPost).getEntity();
|
||||||
return EntityUtils.toString(entity, StandardCharsets.UTF_8);
|
try {
|
||||||
|
response = EntityUtils.toString(entity, StandardCharsets.UTF_8);
|
||||||
|
Map m = (Map) ObjectBuilder.getVal(new JSONParser(new StringReader(response)));
|
||||||
|
assertFalse("Error in posting blob "+ getAsString(m),m.containsKey("error"));
|
||||||
|
} catch (JSONParser.ParseException e) {
|
||||||
|
log.error(response);
|
||||||
|
fail();
|
||||||
|
}
|
||||||
} finally {
|
} finally {
|
||||||
httpPost.releaseConnection();
|
httpPost.releaseConnection();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue