mirror of https://github.com/apache/lucene.git
SOLR-11458: Improve this test to show the failure to be fixed in SOLR-11458.
This commit is contained in:
parent
8e60dc52c5
commit
7c54b2b116
|
@ -701,7 +701,7 @@ public class OverseerCollectionMessageHandler implements OverseerMessageHandler,
|
||||||
log.debug("Expecting {} cores but found {}", coreNames.size(), result.size());
|
log.debug("Expecting {} cores but found {}", coreNames.size(), result.size());
|
||||||
}
|
}
|
||||||
if (timeout.hasTimedOut()) {
|
if (timeout.hasTimedOut()) {
|
||||||
throw new SolrException(ErrorCode.SERVER_ERROR, "Timed out waiting to see all replicas: " + coreNames + " in cluster state.");
|
throw new SolrException(ErrorCode.SERVER_ERROR, "Timed out waiting to see all replicas: " + coreNames + " in cluster state. Last state: " + coll);
|
||||||
}
|
}
|
||||||
|
|
||||||
Thread.sleep(100);
|
Thread.sleep(100);
|
||||||
|
|
|
@ -22,6 +22,7 @@ import org.apache.hadoop.hdfs.MiniDFSCluster;
|
||||||
import org.apache.solr.cloud.hdfs.HdfsTestUtil;
|
import org.apache.solr.cloud.hdfs.HdfsTestUtil;
|
||||||
import org.apache.solr.common.cloud.ZkConfigManager;
|
import org.apache.solr.common.cloud.ZkConfigManager;
|
||||||
import org.apache.solr.util.BadHdfsThreadsFilter;
|
import org.apache.solr.util.BadHdfsThreadsFilter;
|
||||||
|
import org.apache.solr.util.LogLevel;
|
||||||
import org.junit.AfterClass;
|
import org.junit.AfterClass;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
|
|
||||||
|
@ -32,6 +33,7 @@ import org.junit.BeforeClass;
|
||||||
BadHdfsThreadsFilter.class, // hdfs currently leaks thread(s)
|
BadHdfsThreadsFilter.class, // hdfs currently leaks thread(s)
|
||||||
MoveReplicaHDFSTest.ForkJoinThreadsFilter.class
|
MoveReplicaHDFSTest.ForkJoinThreadsFilter.class
|
||||||
})
|
})
|
||||||
|
@LogLevel("org.apache.solr.cloud=DEBUG;org.apache.solr.cloud.autoscaling=DEBUG;")
|
||||||
public class MoveReplicaHDFSTest extends MoveReplicaTest {
|
public class MoveReplicaHDFSTest extends MoveReplicaTest {
|
||||||
|
|
||||||
private static MiniDFSCluster dfsCluster;
|
private static MiniDFSCluster dfsCluster;
|
||||||
|
|
|
@ -28,6 +28,8 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
|
||||||
|
import org.apache.solr.client.solrj.SolrClient;
|
||||||
|
import org.apache.solr.client.solrj.SolrQuery;
|
||||||
import org.apache.solr.client.solrj.SolrServerException;
|
import org.apache.solr.client.solrj.SolrServerException;
|
||||||
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
||||||
import org.apache.solr.client.solrj.impl.CloudSolrClient;
|
import org.apache.solr.client.solrj.impl.CloudSolrClient;
|
||||||
|
@ -36,6 +38,7 @@ import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
||||||
import org.apache.solr.client.solrj.request.CoreAdminRequest;
|
import org.apache.solr.client.solrj.request.CoreAdminRequest;
|
||||||
import org.apache.solr.client.solrj.response.CoreAdminResponse;
|
import org.apache.solr.client.solrj.response.CoreAdminResponse;
|
||||||
import org.apache.solr.client.solrj.response.RequestStatusState;
|
import org.apache.solr.client.solrj.response.RequestStatusState;
|
||||||
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
import org.apache.solr.common.cloud.CollectionStateWatcher;
|
import org.apache.solr.common.cloud.CollectionStateWatcher;
|
||||||
import org.apache.solr.common.cloud.DocCollection;
|
import org.apache.solr.common.cloud.DocCollection;
|
||||||
import org.apache.solr.common.cloud.Replica;
|
import org.apache.solr.common.cloud.Replica;
|
||||||
|
@ -45,12 +48,14 @@ import org.apache.solr.common.params.CollectionParams;
|
||||||
import org.apache.solr.common.params.ModifiableSolrParams;
|
import org.apache.solr.common.params.ModifiableSolrParams;
|
||||||
import org.apache.solr.common.params.SolrParams;
|
import org.apache.solr.common.params.SolrParams;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
|
import org.apache.solr.util.LogLevel;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.BeforeClass;
|
import org.junit.BeforeClass;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
|
@LogLevel("org.apache.solr.cloud=DEBUG;org.apache.solr.cloud.autoscaling=DEBUG;")
|
||||||
public class MoveReplicaTest extends SolrCloudTestCase {
|
public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
|
private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
|
||||||
|
|
||||||
|
@ -101,6 +106,8 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
create.setMaxShardsPerNode(2);
|
create.setMaxShardsPerNode(2);
|
||||||
cloudClient.request(create);
|
cloudClient.request(create);
|
||||||
|
|
||||||
|
addDocs(coll, 100);
|
||||||
|
|
||||||
Replica replica = getRandomReplica(coll, cloudClient);
|
Replica replica = getRandomReplica(coll, cloudClient);
|
||||||
Set<String> liveNodes = cloudClient.getZkStateReader().getClusterState().getLiveNodes();
|
Set<String> liveNodes = cloudClient.getZkStateReader().getClusterState().getLiveNodes();
|
||||||
ArrayList<String> l = new ArrayList<>(liveNodes);
|
ArrayList<String> l = new ArrayList<>(liveNodes);
|
||||||
|
@ -180,6 +187,8 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
}
|
}
|
||||||
assertTrue("replica never fully recovered", recovered);
|
assertTrue("replica never fully recovered", recovered);
|
||||||
|
|
||||||
|
assertEquals(100, cluster.getSolrClient().query(coll, new SolrQuery("*:*")).getResults().getNumFound());
|
||||||
|
|
||||||
Set<CollectionStateWatcher> newWatchers = new HashSet<>(accessor.getStateWatchers(coll));
|
Set<CollectionStateWatcher> newWatchers = new HashSet<>(accessor.getStateWatchers(coll));
|
||||||
assertEquals(watchers, newWatchers);
|
assertEquals(watchers, newWatchers);
|
||||||
|
|
||||||
|
@ -225,6 +234,7 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
assertEquals(watchers, newWatchers);
|
assertEquals(watchers, newWatchers);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl = "https://issues.apache.org/jira/browse/SOLR-11458")
|
||||||
@Test
|
@Test
|
||||||
public void testFailedMove() throws Exception {
|
public void testFailedMove() throws Exception {
|
||||||
String coll = "movereplicatest_failed_coll";
|
String coll = "movereplicatest_failed_coll";
|
||||||
|
@ -237,6 +247,8 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(coll, "conf1", 2, REPLICATION);
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(coll, "conf1", 2, REPLICATION);
|
||||||
cloudClient.request(create);
|
cloudClient.request(create);
|
||||||
|
|
||||||
|
addDocs(coll, 100);
|
||||||
|
|
||||||
Replica replica = getRandomReplica(coll, cloudClient);
|
Replica replica = getRandomReplica(coll, cloudClient);
|
||||||
Set<String> liveNodes = cloudClient.getZkStateReader().getClusterState().getLiveNodes();
|
Set<String> liveNodes = cloudClient.getZkStateReader().getClusterState().getLiveNodes();
|
||||||
ArrayList<String> l = new ArrayList<>(liveNodes);
|
ArrayList<String> l = new ArrayList<>(liveNodes);
|
||||||
|
@ -274,6 +286,8 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
Set<CollectionStateWatcher> newWatchers = new HashSet<>(accessor.getStateWatchers(coll));
|
Set<CollectionStateWatcher> newWatchers = new HashSet<>(accessor.getStateWatchers(coll));
|
||||||
assertEquals(watchers, newWatchers);
|
assertEquals(watchers, newWatchers);
|
||||||
|
log.info("--- current collection state: " + cloudClient.getZkStateReader().getClusterState().getCollection(coll));
|
||||||
|
assertEquals(100, cluster.getSolrClient().query(coll, new SolrQuery("*:*")).getResults().getNumFound());
|
||||||
}
|
}
|
||||||
|
|
||||||
private CollectionAdminRequest.MoveReplica createMoveReplicaRequest(String coll, Replica replica, String targetNode, String shardId) {
|
private CollectionAdminRequest.MoveReplica createMoveReplicaRequest(String coll, Replica replica, String targetNode, String shardId) {
|
||||||
|
@ -351,4 +365,14 @@ public class MoveReplicaTest extends SolrCloudTestCase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void addDocs(String collection, int numDocs) throws Exception {
|
||||||
|
SolrClient solrClient = cluster.getSolrClient();
|
||||||
|
for (int docId = 1; docId <= numDocs; docId++) {
|
||||||
|
SolrInputDocument doc = new SolrInputDocument();
|
||||||
|
doc.addField("id", docId);
|
||||||
|
solrClient.add(collection, doc);
|
||||||
}
|
}
|
||||||
|
solrClient.commit(collection);
|
||||||
|
Thread.sleep(5000);
|
||||||
|
}}
|
||||||
|
|
Loading…
Reference in New Issue