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:
Noble Paul 2015-01-07 10:49:39 +00:00
parent 941f6e64c8
commit 3b988de804
2 changed files with 30 additions and 14 deletions

View File

@ -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{

View File

@ -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();
} }