From 1e4d2052e6ce10b4012eda8802a8d32ccadeeba3 Mon Sep 17 00:00:00 2001 From: Tomas Fernandez Lobbe Date: Thu, 25 May 2017 09:37:16 -0700 Subject: [PATCH] SOLR-10233: ChaosMonkeySafeLeaderWithPullReplicasTest - Catch SolrException while waiting for the cluster to be ready --- .../cloud/ChaosMonkeySafeLeaderWithPullReplicasTest.java | 3 ++- .../src/java/org/apache/solr/cloud/SolrCloudTestCase.java | 6 +++++- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/solr/core/src/test/org/apache/solr/cloud/ChaosMonkeySafeLeaderWithPullReplicasTest.java b/solr/core/src/test/org/apache/solr/cloud/ChaosMonkeySafeLeaderWithPullReplicasTest.java index f2e88453242..e4859c005e5 100644 --- a/solr/core/src/test/org/apache/solr/cloud/ChaosMonkeySafeLeaderWithPullReplicasTest.java +++ b/solr/core/src/test/org/apache/solr/cloud/ChaosMonkeySafeLeaderWithPullReplicasTest.java @@ -27,6 +27,7 @@ import org.apache.solr.SolrTestCaseJ4.SuppressObjectReleaseTracker; import org.apache.solr.client.solrj.SolrQuery; import org.apache.solr.client.solrj.SolrServerException; import org.apache.solr.client.solrj.impl.CloudSolrClient; +import org.apache.solr.common.SolrException; import org.apache.solr.common.SolrInputDocument; import org.apache.solr.common.cloud.DocCollection; import org.apache.solr.common.cloud.Replica; @@ -234,7 +235,7 @@ public class ChaosMonkeySafeLeaderWithPullReplicasTest extends AbstractFullDistr try { del("*:*"); break; - } catch (SolrServerException e) { + } catch (SolrServerException | SolrException e) { // cluster may not be up yet e.printStackTrace(); } diff --git a/solr/test-framework/src/java/org/apache/solr/cloud/SolrCloudTestCase.java b/solr/test-framework/src/java/org/apache/solr/cloud/SolrCloudTestCase.java index 180cf6e88af..42c4577d972 100644 --- a/solr/test-framework/src/java/org/apache/solr/cloud/SolrCloudTestCase.java +++ b/solr/test-framework/src/java/org/apache/solr/cloud/SolrCloudTestCase.java @@ -22,11 +22,13 @@ import java.nio.charset.Charset; import java.nio.file.Files; import java.nio.file.Path; import java.util.ArrayList; +import java.util.Arrays; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.Optional; +import java.util.Set; import java.util.concurrent.TimeUnit; import java.util.concurrent.atomic.AtomicReference; import java.util.function.Predicate; @@ -256,13 +258,15 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 { */ protected void waitForState(String message, String collection, CollectionStatePredicate predicate) { AtomicReference state = new AtomicReference<>(); + AtomicReference> liveNodesLastSeen = new AtomicReference<>(); try { cluster.getSolrClient().waitForState(collection, DEFAULT_TIMEOUT, TimeUnit.SECONDS, (n, c) -> { state.set(c); + liveNodesLastSeen.set(n); return predicate.matches(n, c); }); } catch (Exception e) { - fail(message + "\n" + e.getMessage() + "\nLast available state: " + state.get()); + fail(message + "\n" + e.getMessage() + "\nLive Nodes: " + Arrays.toString(liveNodesLastSeen.get().toArray()) + "\nLast available state: " + state.get()); } }