formatting

This commit is contained in:
noble 2019-08-28 14:34:35 +10:00
parent 5aa9a02421
commit 2835d2e323
1 changed files with 40 additions and 35 deletions

View File

@ -64,7 +64,7 @@ import static org.apache.solr.common.cloud.ZkConfigManager.CONFIGS_ZKNODE;
/** /**
* Base class for SolrCloud tests * Base class for SolrCloud tests
* * <p>
* Derived tests should call {@link #configureCluster(int)} in a {@code BeforeClass} * Derived tests should call {@link #configureCluster(int)} in a {@code BeforeClass}
* static method or {@code Before} setUp method. This configures and starts a {@link MiniSolrCloudCluster}, available * static method or {@code Before} setUp method. This configures and starts a {@link MiniSolrCloudCluster}, available
* via the {@code cluster} variable. Cluster shutdown is handled automatically if using {@code BeforeClass}. * via the {@code cluster} variable. Cluster shutdown is handled automatically if using {@code BeforeClass}.
@ -83,15 +83,15 @@ import static org.apache.solr.common.cloud.ZkConfigManager.CONFIGS_ZKNODE;
public class SolrCloudTestCase extends SolrTestCaseJ4 { public class SolrCloudTestCase extends SolrTestCaseJ4 {
private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass()); private static final Logger log = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
public static final int DEFAULT_TIMEOUT = 45; // this is an important timeout for test stability - can't be too short public static final int DEFAULT_TIMEOUT = 45; // this is an important timeout for test stability - can't be too short
private static class Config { private static class Config {
final String name; final String name;
final Path path; final Path path;
final Map<String,byte[]> extraConfig; final Map<String, byte[]> extraConfig;
private Config(String name, Path path, Map<String,byte[]> extraConfig) { private Config(String name, Path path, Map<String, byte[]> extraConfig) {
this.name = name; this.name = name;
this.path = path; this.path = path;
this.extraConfig = extraConfig; this.extraConfig = extraConfig;
@ -113,8 +113,10 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
private Map<String, Object> clusterProperties = new HashMap<>(); private Map<String, Object> clusterProperties = new HashMap<>();
private boolean trackJettyMetrics; private boolean trackJettyMetrics;
/** /**
* Create a builder * Create a builder
*
* @param nodeCount the number of nodes in the cluster * @param nodeCount the number of nodes in the cluster
* @param baseDir a base directory for the cluster * @param baseDir a base directory for the cluster
*/ */
@ -179,6 +181,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
/** /**
* Upload a collection config before tests start * Upload a collection config before tests start
*
* @param configName the config name * @param configName the config name
* @param configPath the path to the config files * @param configPath the path to the config files
*/ */
@ -194,7 +197,8 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
/** /**
* Set a cluster property * Set a cluster property
* @param propertyName the property name *
* @param propertyName the property name
* @param propertyValue the property value * @param propertyValue the property value
*/ */
public Builder withProperty(String propertyName, String propertyValue) { public Builder withProperty(String propertyName, String propertyValue) {
@ -203,11 +207,13 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
} }
public Builder withMetrics(boolean trackJettyMetrics) { public Builder withMetrics(boolean trackJettyMetrics) {
this.trackJettyMetrics = trackJettyMetrics; this.trackJettyMetrics = trackJettyMetrics;
return this; return this;
} }
/** /**
* Configure and run the {@link MiniSolrCloudCluster} * Configure and run the {@link MiniSolrCloudCluster}
*
* @throws Exception if an error occurs on startup * @throws Exception if an error occurs on startup
*/ */
public MiniSolrCloudCluster configure() throws Exception { public MiniSolrCloudCluster configure() throws Exception {
@ -216,6 +222,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
/** /**
* Configure, run and return the {@link MiniSolrCloudCluster} * Configure, run and return the {@link MiniSolrCloudCluster}
*
* @throws Exception if an error occurs on startup * @throws Exception if an error occurs on startup
*/ */
public MiniSolrCloudCluster build() throws Exception { public MiniSolrCloudCluster build() throws Exception {
@ -223,11 +230,11 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
null, securityJson, trackJettyMetrics); null, securityJson, trackJettyMetrics);
CloudSolrClient client = cluster.getSolrClient(); CloudSolrClient client = cluster.getSolrClient();
for (Config config : configs) { for (Config config : configs) {
((ZkClientClusterStateProvider)client.getClusterStateProvider()).uploadConfig(config.path, config.name); ((ZkClientClusterStateProvider) client.getClusterStateProvider()).uploadConfig(config.path, config.name);
if(config.extraConfig!= null){ if (config.extraConfig != null) {
for (Map.Entry<String, byte[]> e : config.extraConfig.entrySet()) { for (Map.Entry<String, byte[]> e : config.extraConfig.entrySet()) {
((ZkClientClusterStateProvider)client.getClusterStateProvider()).getZkStateReader().getZkClient() ((ZkClientClusterStateProvider) client.getClusterStateProvider()).getZkStateReader().getZkClient()
.create(CONFIGS_ZKNODE + "/" + config.name+ "/"+ e.getKey(), e.getValue(), CreateMode.PERSISTENT, true); .create(CONFIGS_ZKNODE + "/" + config.name + "/" + e.getKey(), e.getValue(), CreateMode.PERSISTENT, true);
} }
@ -244,12 +251,12 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
} }
public Builder withDefaultClusterProperty(String key, String value) { public Builder withDefaultClusterProperty(String key, String value) {
HashMap<String,Object> defaults = (HashMap<String, Object>) this.clusterProperties.get(CollectionAdminParams.DEFAULTS); HashMap<String, Object> defaults = (HashMap<String, Object>) this.clusterProperties.get(CollectionAdminParams.DEFAULTS);
if (defaults == null) { if (defaults == null) {
defaults = new HashMap<>(); defaults = new HashMap<>();
this.clusterProperties.put(CollectionAdminParams.DEFAULTS, defaults); this.clusterProperties.put(CollectionAdminParams.DEFAULTS, defaults);
} }
HashMap<String,Object> cluster = (HashMap<String, Object>) defaults.get(CollectionAdminParams.CLUSTER); HashMap<String, Object> cluster = (HashMap<String, Object>) defaults.get(CollectionAdminParams.CLUSTER);
if (cluster == null) { if (cluster == null) {
cluster = new HashMap<>(); cluster = new HashMap<>();
defaults.put(CollectionAdminParams.CLUSTER, cluster); defaults.put(CollectionAdminParams.CLUSTER, cluster);
@ -259,7 +266,9 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
} }
} }
/** The cluster */ /**
* The cluster
*/
protected static volatile MiniSolrCloudCluster cluster; protected static volatile MiniSolrCloudCluster cluster;
protected static SolrZkClient zkClient() { protected static SolrZkClient zkClient() {
@ -271,7 +280,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
/** /**
* Call this to configure a cluster of n nodes. * Call this to configure a cluster of n nodes.
* * <p>
* NB you must call {@link Builder#configure()} to start the cluster * NB you must call {@link Builder#configure()} to start the cluster
* *
* @param nodeCount the number of nodes * @param nodeCount the number of nodes
@ -305,15 +314,15 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
protected static void waitForState(String message, String collection, CollectionStatePredicate predicate) { protected static void waitForState(String message, String collection, CollectionStatePredicate predicate) {
waitForState(message, collection, predicate, DEFAULT_TIMEOUT, TimeUnit.SECONDS); waitForState(message, collection, predicate, DEFAULT_TIMEOUT, TimeUnit.SECONDS);
} }
/** /**
* Wait for a particular collection state to appear in the cluster client's state reader * Wait for a particular collection state to appear in the cluster client's state reader
* * <p>
* This is a convenience method using the {@link #DEFAULT_TIMEOUT} * This is a convenience method using the {@link #DEFAULT_TIMEOUT}
* *
* @param message a message to report on failure * @param message a message to report on failure
* @param collection the collection to watch * @param collection the collection to watch
* @param predicate a predicate to match against the collection state * @param predicate a predicate to match against the collection state
*/ */
protected static void waitForState(String message, String collection, CollectionStatePredicate predicate, int timeout, TimeUnit timeUnit) { protected static void waitForState(String message, String collection, CollectionStatePredicate predicate, int timeout, TimeUnit timeUnit) {
log.info("waitForState ({}): {}", collection, message); log.info("waitForState ({}): {}", collection, message);
@ -340,8 +349,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
return false; return false;
if (collectionState.getSlices().size() != expectedShards) if (collectionState.getSlices().size() != expectedShards)
return false; return false;
if (compareActiveReplicaCountsForShards(expectedReplicas, liveNodes, collectionState)) return true; return compareActiveReplicaCountsForShards(expectedReplicas, liveNodes, collectionState);
return false;
}; };
} }
@ -356,23 +364,22 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
log.info("active slice count: " + collectionState.getActiveSlices().size() + " expected:" + expectedShards); log.info("active slice count: " + collectionState.getActiveSlices().size() + " expected:" + expectedShards);
if (collectionState.getActiveSlices().size() != expectedShards) if (collectionState.getActiveSlices().size() != expectedShards)
return false; return false;
if (compareActiveReplicaCountsForShards(expectedReplicas, liveNodes, collectionState)) return true; return compareActiveReplicaCountsForShards(expectedReplicas, liveNodes, collectionState);
return false;
}; };
} }
public static LiveNodesPredicate containsLiveNode(String node) { public static LiveNodesPredicate containsLiveNode(String node) {
return (oldNodes, newNodes) -> { return (oldNodes, newNodes) -> {
return newNodes.contains(node); return newNodes.contains(node);
}; };
} }
public static LiveNodesPredicate missingLiveNode(String node) { public static LiveNodesPredicate missingLiveNode(String node) {
return (oldNodes, newNodes) -> { return (oldNodes, newNodes) -> {
return !newNodes.contains(node); return !newNodes.contains(node);
}; };
} }
public static LiveNodesPredicate missingLiveNodes(List<String> nodes) { public static LiveNodesPredicate missingLiveNodes(List<String> nodes) {
return (oldNodes, newNodes) -> { return (oldNodes, newNodes) -> {
boolean success = true; boolean success = true;
@ -395,14 +402,11 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
} }
} }
} }
log.info("active replica count: " + activeReplicas + " expected replica count: " + expectedReplicas);
if (activeReplicas == expectedReplicas) {
return true;
}
return false; log.info("active replica count: " + activeReplicas + " expected replica count: " + expectedReplicas);
return activeReplicas == expectedReplicas;
} }
/** /**
@ -445,7 +449,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
/** /**
* Get the {@link CoreStatus} data for a {@link Replica} * Get the {@link CoreStatus} data for a {@link Replica}
* * <p>
* This assumes that the replica is hosted on a live node. * This assumes that the replica is hosted on a live node.
*/ */
protected static CoreStatus getCoreStatus(Replica replica) throws IOException, SolrServerException { protected static CoreStatus getCoreStatus(Replica replica) throws IOException, SolrServerException {
@ -476,6 +480,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
/** /**
* Ensure that the given number of solr instances are running. If less instances are found then new instances are * Ensure that the given number of solr instances are running. If less instances are found then new instances are
* started. If extra instances are found then they are stopped. * started. If extra instances are found then they are stopped.
*
* @param nodeCount the number of Solr instances that should be running at the end of this method * @param nodeCount the number of Solr instances that should be running at the end of this method
* @throws Exception on error * @throws Exception on error
*/ */
@ -484,7 +489,7 @@ public class SolrCloudTestCase extends SolrTestCaseJ4 {
List<JettySolrRunner> jettys = cluster.getJettySolrRunners(); List<JettySolrRunner> jettys = cluster.getJettySolrRunners();
List<JettySolrRunner> copyOfJettys = new ArrayList<>(jettys); List<JettySolrRunner> copyOfJettys = new ArrayList<>(jettys);
int numJetties = copyOfJettys.size(); int numJetties = copyOfJettys.size();
for (int i = nodeCount; i < numJetties; i++) { for (int i = nodeCount; i < numJetties; i++) {
cluster.stopJettySolrRunner(copyOfJettys.get(i)); cluster.stopJettySolrRunner(copyOfJettys.get(i));
} }
for (int i = copyOfJettys.size(); i < nodeCount; i++) { for (int i = copyOfJettys.size(); i < nodeCount; i++) {