mirror of https://github.com/apache/lucene.git
Merge branch 'master' of https://git-wip-us.apache.org/repos/asf/lucene-solr
This commit is contained in:
commit
3291ef884d
|
@ -201,6 +201,8 @@ Other Changes
|
||||||
* SOLR-10752: replicationFactor (nrtReplicas) default is 0 if tlogReplicas is specified when creating a collection
|
* SOLR-10752: replicationFactor (nrtReplicas) default is 0 if tlogReplicas is specified when creating a collection
|
||||||
(Tomás Fernández Löbbe)
|
(Tomás Fernández Löbbe)
|
||||||
|
|
||||||
|
* SOLR-10757: delete/refactor/cleanup CollectionAdminRequest deprecations (hossman)
|
||||||
|
|
||||||
================== 6.7.0 ==================
|
================== 6.7.0 ==================
|
||||||
|
|
||||||
Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
|
Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
|
||||||
|
@ -248,6 +250,9 @@ Bug Fixes
|
||||||
* SOLR-10719: Creating a core.properties fails if the parent of core.properties is a symlinked dierctory
|
* SOLR-10719: Creating a core.properties fails if the parent of core.properties is a symlinked dierctory
|
||||||
(Erick Erickson)
|
(Erick Erickson)
|
||||||
|
|
||||||
|
* SOLR-10360: Solr HDFS snapshot export fails due to FileNotFoundException error when using MR1 instead of
|
||||||
|
yarn. (Hrishikesh via Mark Miller)
|
||||||
|
|
||||||
Optimizations
|
Optimizations
|
||||||
----------------------
|
----------------------
|
||||||
* SOLR-10634: JSON Facet API: When a field/terms facet will retrieve all buckets (i.e. limit:-1)
|
* SOLR-10634: JSON Facet API: When a field/terms facet will retrieve all buckets (i.e. limit:-1)
|
||||||
|
|
|
@ -301,11 +301,8 @@ public class SolrSnapshotsTool implements Closeable {
|
||||||
if (backupRepo.isPresent()) {
|
if (backupRepo.isPresent()) {
|
||||||
backup.setRepositoryName(backupRepo.get());
|
backup.setRepositoryName(backupRepo.get());
|
||||||
}
|
}
|
||||||
if (asyncReqId.isPresent()) {
|
// if asyncId is null, processAsync will block and throw an Exception with any error
|
||||||
backup.setAsyncId(asyncReqId.get());
|
backup.processAsync(asyncReqId.orElse(null), solrClient);
|
||||||
}
|
|
||||||
CollectionAdminResponse resp = backup.process(solrClient);
|
|
||||||
Preconditions.checkState(resp.getStatus() == 0, "The request failed. The status code is " + resp.getStatus());
|
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
log.error("Failed to backup collection meta-data for collection " + collectionName, e);
|
log.error("Failed to backup collection meta-data for collection " + collectionName, e);
|
||||||
System.out.println("Failed to backup collection meta-data for collection " + collectionName
|
System.out.println("Failed to backup collection meta-data for collection " + collectionName
|
||||||
|
|
|
@ -87,8 +87,12 @@ public abstract class AbstractCloudBackupRestoreTestCase extends SolrCloudTestCa
|
||||||
int replFactor = TestUtil.nextInt(random(), 1, 2);
|
int replFactor = TestUtil.nextInt(random(), 1, 2);
|
||||||
int numTlogReplicas = TestUtil.nextInt(random(), 0, 1);
|
int numTlogReplicas = TestUtil.nextInt(random(), 0, 1);
|
||||||
int numPullReplicas = TestUtil.nextInt(random(), 0, 1);
|
int numPullReplicas = TestUtil.nextInt(random(), 0, 1);
|
||||||
CollectionAdminRequest.Create create =
|
|
||||||
CollectionAdminRequest.createCollection(getCollectionName(), "conf1", NUM_SHARDS, replFactor, numTlogReplicas, numPullReplicas);
|
CollectionAdminRequest.Create create = isImplicit ?
|
||||||
|
// NOTE: use shard list with same # of shards as NUM_SHARDS; we assume this later
|
||||||
|
CollectionAdminRequest.createCollectionWithImplicitRouter(getCollectionName(), "conf1", "shard1,shard2", replFactor, numTlogReplicas, numPullReplicas) :
|
||||||
|
CollectionAdminRequest.createCollection(getCollectionName(), "conf1", NUM_SHARDS, replFactor, numTlogReplicas, numPullReplicas);
|
||||||
|
|
||||||
if (NUM_SHARDS * (replFactor + numTlogReplicas + numPullReplicas) > cluster.getJettySolrRunners().size() || random().nextBoolean()) {
|
if (NUM_SHARDS * (replFactor + numTlogReplicas + numPullReplicas) > cluster.getJettySolrRunners().size() || random().nextBoolean()) {
|
||||||
create.setMaxShardsPerNode((int)Math.ceil(NUM_SHARDS * (replFactor + numTlogReplicas + numPullReplicas) / cluster.getJettySolrRunners().size()));//just to assert it survives the restoration
|
create.setMaxShardsPerNode((int)Math.ceil(NUM_SHARDS * (replFactor + numTlogReplicas + numPullReplicas) / cluster.getJettySolrRunners().size()));//just to assert it survives the restoration
|
||||||
if (doSplitShardOperation) {
|
if (doSplitShardOperation) {
|
||||||
|
@ -102,9 +106,6 @@ public abstract class AbstractCloudBackupRestoreTestCase extends SolrCloudTestCa
|
||||||
coreProps.put("customKey", "customValue");//just to assert it survives the restoration
|
coreProps.put("customKey", "customValue");//just to assert it survives the restoration
|
||||||
create.setProperties(coreProps);
|
create.setProperties(coreProps);
|
||||||
if (isImplicit) { //implicit router
|
if (isImplicit) { //implicit router
|
||||||
create.setRouterName(ImplicitDocRouter.NAME);
|
|
||||||
create.setNumShards(null);//erase it. TODO suggest a new createCollectionWithImplicitRouter method
|
|
||||||
create.setShards("shard1,shard2"); // however still same number as NUM_SHARDS; we assume this later
|
|
||||||
create.setRouterField("shard_s");
|
create.setRouterField("shard_s");
|
||||||
} else {//composite id router
|
} else {//composite id router
|
||||||
if (random().nextBoolean()) {
|
if (random().nextBoolean()) {
|
||||||
|
|
|
@ -24,8 +24,6 @@ import org.apache.lucene.util.TestUtil;
|
||||||
import org.apache.solr.client.solrj.SolrQuery;
|
import org.apache.solr.client.solrj.SolrQuery;
|
||||||
import org.apache.solr.client.solrj.impl.CloudSolrClient;
|
import org.apache.solr.client.solrj.impl.CloudSolrClient;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.Create;
|
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.SplitShard;
|
|
||||||
import org.apache.solr.client.solrj.response.RequestStatusState;
|
import org.apache.solr.client.solrj.response.RequestStatusState;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.SolrInputDocument;
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
|
@ -54,29 +52,19 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
final CloudSolrClient client = cluster.getSolrClient();
|
final CloudSolrClient client = cluster.getSolrClient();
|
||||||
|
|
||||||
RequestStatusState state = new Create()
|
RequestStatusState state = CollectionAdminRequest.createCollection("testasynccollectioncreation","conf1",1,1)
|
||||||
.setCollectionName("testasynccollectioncreation")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("CreateCollection task did not complete!", RequestStatusState.COMPLETED, state);
|
assertSame("CreateCollection task did not complete!", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
state = new Create()
|
state = CollectionAdminRequest.createCollection("testasynccollectioncreation","conf1",1,1)
|
||||||
.setCollectionName("testasynccollectioncreation")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("Recreating a collection with the same should have failed.", RequestStatusState.FAILED, state);
|
assertSame("Recreating a collection with the same should have failed.", RequestStatusState.FAILED, state);
|
||||||
|
|
||||||
state = new CollectionAdminRequest.AddReplica()
|
state = CollectionAdminRequest.addReplicaToShard("testasynccollectioncreation", "shard1")
|
||||||
.setCollectionName("testasynccollectioncreation")
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
.setShardName("shard1")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
|
||||||
assertSame("Add replica did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("Add replica did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
state = new SplitShard()
|
state = CollectionAdminRequest.splitShard("testasynccollectioncreation")
|
||||||
.setCollectionName("testasynccollectioncreation")
|
|
||||||
.setShardName("shard1")
|
.setShardName("shard1")
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS * 2);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS * 2);
|
||||||
assertEquals("Shard split did not complete. Last recorded state: " + state, RequestStatusState.COMPLETED, state);
|
assertEquals("Shard split did not complete. Last recorded state: " + state, RequestStatusState.COMPLETED, state);
|
||||||
|
@ -89,12 +77,9 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
final String collection = "testAsyncOperations";
|
final String collection = "testAsyncOperations";
|
||||||
final CloudSolrClient client = cluster.getSolrClient();
|
final CloudSolrClient client = cluster.getSolrClient();
|
||||||
|
|
||||||
RequestStatusState state = new Create()
|
RequestStatusState state = CollectionAdminRequest.createCollection(collection,"conf1",1,1)
|
||||||
.setCollectionName(collection)
|
|
||||||
.setNumShards(1)
|
|
||||||
.setRouterName("implicit")
|
.setRouterName("implicit")
|
||||||
.setShards("shard1")
|
.setShards("shard1")
|
||||||
.setConfigName("conf1")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("CreateCollection task did not complete!", RequestStatusState.COMPLETED, state);
|
assertSame("CreateCollection task did not complete!", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
|
@ -114,14 +99,11 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
query.set("shards", "shard1");
|
query.set("shards", "shard1");
|
||||||
assertEquals(numDocs, client.query(collection, query).getResults().getNumFound());
|
assertEquals(numDocs, client.query(collection, query).getResults().getNumFound());
|
||||||
|
|
||||||
state = new CollectionAdminRequest.Reload()
|
state = CollectionAdminRequest.reloadCollection(collection)
|
||||||
.setCollectionName(collection)
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("ReloadCollection did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("ReloadCollection did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
state = new CollectionAdminRequest.CreateShard()
|
state = CollectionAdminRequest.createShard(collection,"shard2")
|
||||||
.setCollectionName(collection)
|
|
||||||
.setShardName("shard2")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("CreateShard did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("CreateShard did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
|
@ -135,16 +117,11 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
query.set("shards", "shard2");
|
query.set("shards", "shard2");
|
||||||
assertEquals(1, client.query(collection, query).getResults().getNumFound());
|
assertEquals(1, client.query(collection, query).getResults().getNumFound());
|
||||||
|
|
||||||
state = new CollectionAdminRequest.DeleteShard()
|
state = CollectionAdminRequest.deleteShard(collection,"shard2").processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
.setCollectionName(collection)
|
|
||||||
.setShardName("shard2")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
|
||||||
assertSame("DeleteShard did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("DeleteShard did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
state = new CollectionAdminRequest.AddReplica()
|
state = CollectionAdminRequest.addReplicaToShard(collection, "shard1")
|
||||||
.setCollectionName(collection)
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
.setShardName("shard1")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
|
||||||
assertSame("AddReplica did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("AddReplica did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
//cloudClient watch might take a couple of seconds to reflect it
|
//cloudClient watch might take a couple of seconds to reflect it
|
||||||
|
@ -157,9 +134,7 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
Thread.sleep(100);
|
Thread.sleep(100);
|
||||||
}
|
}
|
||||||
|
|
||||||
state = new CollectionAdminRequest.CreateAlias()
|
state = CollectionAdminRequest.createAlias("myalias",collection)
|
||||||
.setAliasName("myalias")
|
|
||||||
.setAliasedCollections(collection)
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("CreateAlias did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("CreateAlias did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
|
@ -167,8 +142,7 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
query.set("shards", "shard1");
|
query.set("shards", "shard1");
|
||||||
assertEquals(numDocs, client.query("myalias", query).getResults().getNumFound());
|
assertEquals(numDocs, client.query("myalias", query).getResults().getNumFound());
|
||||||
|
|
||||||
state = new CollectionAdminRequest.DeleteAlias()
|
state = CollectionAdminRequest.deleteAlias("myalias")
|
||||||
.setAliasName("myalias")
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("DeleteAlias did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("DeleteAlias did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
|
@ -191,15 +165,11 @@ public class CollectionsAPIAsyncDistributedZkTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
shard1 = client.getZkStateReader().getClusterState().getSlice(collection, "shard1");
|
shard1 = client.getZkStateReader().getClusterState().getSlice(collection, "shard1");
|
||||||
String replicaName = shard1.getReplicas().iterator().next().getName();
|
String replicaName = shard1.getReplicas().iterator().next().getName();
|
||||||
state = new CollectionAdminRequest.DeleteReplica()
|
state = CollectionAdminRequest.deleteReplica(collection, "shard1", replicaName)
|
||||||
.setCollectionName(collection)
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
.setShardName("shard1")
|
|
||||||
.setReplica(replicaName)
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
|
||||||
assertSame("DeleteReplica did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("DeleteReplica did not complete", RequestStatusState.COMPLETED, state);
|
||||||
|
|
||||||
state = new CollectionAdminRequest.Delete()
|
state = CollectionAdminRequest.deleteCollection(collection)
|
||||||
.setCollectionName(collection)
|
|
||||||
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
.processAndWait(client, MAX_TIMEOUT_SECONDS);
|
||||||
assertSame("DeleteCollection did not complete", RequestStatusState.COMPLETED, state);
|
assertSame("DeleteCollection did not complete", RequestStatusState.COMPLETED, state);
|
||||||
}
|
}
|
||||||
|
|
|
@ -267,17 +267,21 @@ public class CollectionsAPISolrJTest extends SolrCloudTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testClusterProp() throws InterruptedException, IOException, SolrServerException {
|
public void testClusterProp() throws InterruptedException, IOException, SolrServerException {
|
||||||
|
|
||||||
|
// sanity check our expected default
|
||||||
|
final ClusterProperties props = new ClusterProperties(zkClient());
|
||||||
|
assertEquals("Expecting prop to default to unset, test needs upated",
|
||||||
|
props.getClusterProperty(ZkStateReader.LEGACY_CLOUD, null), null);
|
||||||
|
|
||||||
CollectionAdminResponse response = CollectionAdminRequest.setClusterProperty(ZkStateReader.LEGACY_CLOUD, "false")
|
CollectionAdminResponse response = CollectionAdminRequest.setClusterProperty(ZkStateReader.LEGACY_CLOUD, "false")
|
||||||
.process(cluster.getSolrClient());
|
.process(cluster.getSolrClient());
|
||||||
|
|
||||||
assertEquals(0, response.getStatus());
|
assertEquals(0, response.getStatus());
|
||||||
|
|
||||||
ClusterProperties props = new ClusterProperties(zkClient());
|
assertEquals("Cluster property was not set", props.getClusterProperty(ZkStateReader.LEGACY_CLOUD, null), "false");
|
||||||
assertEquals("Cluster property was not set", props.getClusterProperty(ZkStateReader.LEGACY_CLOUD, "true"), "false");
|
|
||||||
|
|
||||||
// Unset ClusterProp that we set.
|
// Unset ClusterProp that we set.
|
||||||
CollectionAdminRequest.setClusterProperty(ZkStateReader.LEGACY_CLOUD, null).process(cluster.getSolrClient());
|
CollectionAdminRequest.setClusterProperty(ZkStateReader.LEGACY_CLOUD, null).process(cluster.getSolrClient());
|
||||||
assertEquals("Cluster property was not unset", props.getClusterProperty(ZkStateReader.LEGACY_CLOUD, "true"), "true");
|
assertEquals("Cluster property was not unset", props.getClusterProperty(ZkStateReader.LEGACY_CLOUD, null), null);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -164,11 +164,8 @@ public class ConcurrentDeleteAndCreateCollectionTest extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
private void createCollection() {
|
private void createCollection() {
|
||||||
try {
|
try {
|
||||||
final CollectionAdminResponse response = new CollectionAdminRequest.Create()
|
final CollectionAdminResponse response = CollectionAdminRequest.createCollection(collectionName,configName,1,1)
|
||||||
.setCollectionName(collectionName)
|
.process(solrClient);
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setConfigName(configName).process(solrClient);
|
|
||||||
if (response.getStatus() != 0) {
|
if (response.getStatus() != 0) {
|
||||||
addFailure(new RuntimeException("failed to create collection " + collectionName));
|
addFailure(new RuntimeException("failed to create collection " + collectionName));
|
||||||
}
|
}
|
||||||
|
@ -180,9 +177,8 @@ public class ConcurrentDeleteAndCreateCollectionTest extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
private void deleteCollection() {
|
private void deleteCollection() {
|
||||||
try {
|
try {
|
||||||
final CollectionAdminRequest.Delete deleteCollectionRequest = new CollectionAdminRequest.Delete()
|
final CollectionAdminRequest.Delete deleteCollectionRequest
|
||||||
.setCollectionName(collectionName);
|
= CollectionAdminRequest.deleteCollection(collectionName);
|
||||||
|
|
||||||
final CollectionAdminResponse response = deleteCollectionRequest.process(solrClient);
|
final CollectionAdminResponse response = deleteCollectionRequest.process(solrClient);
|
||||||
if (response.getStatus() != 0) {
|
if (response.getStatus() != 0) {
|
||||||
addFailure(new RuntimeException("failed to delete collection " + collectionName));
|
addFailure(new RuntimeException("failed to delete collection " + collectionName));
|
||||||
|
|
|
@ -120,27 +120,4 @@ public class DeleteStatusTest extends SolrCloudTestCase {
|
||||||
CollectionAdminRequest.requestStatus(id2).process(client).getRequestStatus());
|
CollectionAdminRequest.requestStatus(id2).process(client).getRequestStatus());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
|
||||||
@SuppressWarnings("deprecation")
|
|
||||||
public void testDeprecatedConstructorValidation() throws Exception {
|
|
||||||
|
|
||||||
final CloudSolrClient client = cluster.getSolrClient();
|
|
||||||
|
|
||||||
try {
|
|
||||||
new CollectionAdminRequest.DeleteStatus().process(client);
|
|
||||||
fail("delete status should have failed");
|
|
||||||
} catch (IllegalArgumentException e) {
|
|
||||||
assertTrue(e.getMessage().contains("Either requestid or flush parameter must be specified."));
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
|
||||||
new CollectionAdminRequest.DeleteStatus().setFlush(true)
|
|
||||||
.setRequestId("foo")
|
|
||||||
.process(client);
|
|
||||||
fail("delete status should have failed");
|
|
||||||
} catch (IllegalArgumentException e) {
|
|
||||||
assertTrue(e.getMessage().contains("Both requestid and flush parameters can not be specified together."));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -152,14 +152,7 @@ public class ForceLeaderTest extends HttpPartitionTest {
|
||||||
} finally {
|
} finally {
|
||||||
log.info("Cleaning up after the test.");
|
log.info("Cleaning up after the test.");
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -206,15 +199,7 @@ public class ForceLeaderTest extends HttpPartitionTest {
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
log.info("Cleaning up after the test.");
|
log.info("Cleaning up after the test.");
|
||||||
// try to clean up
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
try {
|
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -431,10 +416,8 @@ public class ForceLeaderTest extends HttpPartitionTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void doForceLeader(SolrClient client, String collectionName, String shard) throws IOException, SolrServerException {
|
private void doForceLeader(SolrClient client, String collectionName, String shard) throws IOException, SolrServerException {
|
||||||
CollectionAdminRequest.ForceLeader forceLeader = new CollectionAdminRequest.ForceLeader();
|
CollectionAdminRequest.ForceLeader forceLeader = CollectionAdminRequest.forceLeaderElection(collectionName, shard);
|
||||||
forceLeader.setCollectionName(collectionName);
|
client.request(forceLeader);
|
||||||
forceLeader.setShardName(shard);
|
|
||||||
client.request(forceLeader);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected int getNumberOfActiveReplicas(ClusterState clusterState, String collection, String sliceId) {
|
protected int getNumberOfActiveReplicas(ClusterState clusterState, String collection, String sliceId) {
|
||||||
|
|
|
@ -157,13 +157,9 @@ public class FullSolrCloudDistribCmdsTest extends AbstractFullDistribZkTestBase
|
||||||
CollectionAdminResponse response;
|
CollectionAdminResponse response;
|
||||||
Map<String, NamedList<Integer>> coresStatus;
|
Map<String, NamedList<Integer>> coresStatus;
|
||||||
|
|
||||||
CollectionAdminRequest.Create createCollectionRequest = new CollectionAdminRequest.Create()
|
CollectionAdminRequest.Create createCollectionRequest
|
||||||
.setCollectionName("implicit_collection_without_routerfield")
|
= CollectionAdminRequest.createCollectionWithImplicitRouter("implicit_collection_without_routerfield",
|
||||||
.setRouterName("implicit")
|
"conf1","shard1,shard2",2);
|
||||||
.setNumShards(2)
|
|
||||||
.setShards("shard1,shard2")
|
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setConfigName("conf1");
|
|
||||||
response = createCollectionRequest.process(server);
|
response = createCollectionRequest.process(server);
|
||||||
|
|
||||||
assertEquals(0, response.getStatus());
|
assertEquals(0, response.getStatus());
|
||||||
|
@ -285,14 +281,10 @@ public class FullSolrCloudDistribCmdsTest extends AbstractFullDistribZkTestBase
|
||||||
CollectionAdminResponse response;
|
CollectionAdminResponse response;
|
||||||
Map<String, NamedList<Integer>> coresStatus;
|
Map<String, NamedList<Integer>> coresStatus;
|
||||||
|
|
||||||
response = new CollectionAdminRequest.Create()
|
response = CollectionAdminRequest.createCollection("compositeid_collection_with_routerfield","conf1",2,2)
|
||||||
.setCollectionName("compositeid_collection_with_routerfield")
|
|
||||||
.setRouterName("compositeId")
|
.setRouterName("compositeId")
|
||||||
.setRouterField("routefield_s")
|
.setRouterField("routefield_s")
|
||||||
.setNumShards(2)
|
|
||||||
.setShards("shard1,shard2")
|
.setShards("shard1,shard2")
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.process(server);
|
.process(server);
|
||||||
|
|
||||||
assertEquals(0, response.getStatus());
|
assertEquals(0, response.getStatus());
|
||||||
|
|
|
@ -37,7 +37,6 @@ 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;
|
||||||
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
|
||||||
import org.apache.solr.client.solrj.request.QueryRequest;
|
import org.apache.solr.client.solrj.request.QueryRequest;
|
||||||
import org.apache.solr.client.solrj.request.UpdateRequest;
|
import org.apache.solr.client.solrj.request.UpdateRequest;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
@ -199,13 +198,7 @@ public class HttpPartitionTest extends AbstractFullDistribZkTestBase {
|
||||||
zkClient.delete(znodePath, -1, false);
|
zkClient.delete(znodePath, -1, false);
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
new CollectionAdminRequest.Delete()
|
|
||||||
.setCollectionName(testCollectionName).process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void testMinRf() throws Exception {
|
protected void testMinRf() throws Exception {
|
||||||
|
@ -387,13 +380,7 @@ public class HttpPartitionTest extends AbstractFullDistribZkTestBase {
|
||||||
log.info("testRf2 succeeded ... deleting the "+testCollectionName+" collection");
|
log.info("testRf2 succeeded ... deleting the "+testCollectionName+" collection");
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
new CollectionAdminRequest.Delete()
|
|
||||||
.setCollectionName(testCollectionName).process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void testRf3() throws Exception {
|
protected void testRf3() throws Exception {
|
||||||
|
@ -443,14 +430,7 @@ public class HttpPartitionTest extends AbstractFullDistribZkTestBase {
|
||||||
log.info("testRf3 succeeded ... deleting the "+testCollectionName+" collection");
|
log.info("testRf3 succeeded ... deleting the "+testCollectionName+" collection");
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// test inspired by SOLR-6511
|
// test inspired by SOLR-6511
|
||||||
|
@ -534,14 +514,7 @@ public class HttpPartitionTest extends AbstractFullDistribZkTestBase {
|
||||||
log.info("testLeaderZkSessionLoss succeeded ... deleting the "+testCollectionName+" collection");
|
log.info("testLeaderZkSessionLoss succeeded ... deleting the "+testCollectionName+" collection");
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected List<Replica> getActiveOrRecoveringReplicas(String testCollectionName, String shardId) throws Exception {
|
protected List<Replica> getActiveOrRecoveringReplicas(String testCollectionName, String shardId) throws Exception {
|
||||||
|
@ -693,4 +666,5 @@ public class HttpPartitionTest extends AbstractFullDistribZkTestBase {
|
||||||
|
|
||||||
log.info("Took {} ms to see replicas [{}] become active.", timer.getTime(), replicasToCheck);
|
log.info("Took {} ms to see replicas [{}] become active.", timer.getTime(), replicasToCheck);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,7 +20,6 @@ import org.apache.lucene.util.LuceneTestCase.Slow;
|
||||||
import org.apache.solr.SolrTestCaseJ4.SuppressSSL;
|
import org.apache.solr.SolrTestCaseJ4.SuppressSSL;
|
||||||
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
||||||
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
|
||||||
import org.apache.solr.common.SolrInputDocument;
|
import org.apache.solr.common.SolrInputDocument;
|
||||||
import org.apache.solr.common.cloud.Replica;
|
import org.apache.solr.common.cloud.Replica;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
@ -184,13 +183,6 @@ public class LeaderFailoverAfterPartitionTest extends HttpPartitionTest {
|
||||||
assertDocsExistInAllReplicas(participatingReplicas, testCollectionName, 1, 6);
|
assertDocsExistInAllReplicas(participatingReplicas, testCollectionName, 1, 6);
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -19,7 +19,6 @@ package org.apache.solr.cloud;
|
||||||
import org.apache.http.NoHttpResponseException;
|
import org.apache.http.NoHttpResponseException;
|
||||||
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
import org.apache.solr.client.solrj.embedded.JettySolrRunner;
|
||||||
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
import org.apache.solr.common.cloud.Replica;
|
import org.apache.solr.common.cloud.Replica;
|
||||||
import org.apache.solr.util.RTimer;
|
import org.apache.solr.util.RTimer;
|
||||||
|
@ -96,14 +95,7 @@ public class LeaderInitiatedRecoveryOnCommitTest extends BasicDistributedZkTest
|
||||||
Thread.sleep(sleepMsBeforeHealPartition);
|
Thread.sleep(sleepMsBeforeHealPartition);
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
|
|
||||||
log.info("multiShardTest completed OK");
|
log.info("multiShardTest completed OK");
|
||||||
}
|
}
|
||||||
|
@ -144,14 +136,7 @@ public class LeaderInitiatedRecoveryOnCommitTest extends BasicDistributedZkTest
|
||||||
Thread.sleep(sleepMsBeforeHealPartition);
|
Thread.sleep(sleepMsBeforeHealPartition);
|
||||||
|
|
||||||
// try to clean up
|
// try to clean up
|
||||||
try {
|
attemptCollectionDelete(cloudClient, testCollectionName);
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
} catch (Exception e) {
|
|
||||||
// don't fail the test
|
|
||||||
log.warn("Could not delete collection {} after test completed", testCollectionName);
|
|
||||||
}
|
|
||||||
|
|
||||||
log.info("oneShardTest completed OK");
|
log.info("oneShardTest completed OK");
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,6 +24,7 @@ import org.apache.solr.client.solrj.SolrClient;
|
||||||
import org.apache.solr.client.solrj.SolrRequest;
|
import org.apache.solr.client.solrj.SolrRequest;
|
||||||
import org.apache.solr.client.solrj.SolrServerException;
|
import org.apache.solr.client.solrj.SolrServerException;
|
||||||
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
import org.apache.solr.client.solrj.impl.HttpSolrClient;
|
||||||
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.Create;
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest.Create;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.SplitShard;
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest.SplitShard;
|
||||||
import org.apache.solr.client.solrj.request.QueryRequest;
|
import org.apache.solr.client.solrj.request.QueryRequest;
|
||||||
|
@ -31,7 +32,6 @@ import org.apache.solr.client.solrj.response.CollectionAdminResponse;
|
||||||
import org.apache.solr.client.solrj.response.RequestStatusState;
|
import org.apache.solr.client.solrj.response.RequestStatusState;
|
||||||
import org.apache.solr.common.params.CollectionParams;
|
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.util.NamedList;
|
|
||||||
import org.apache.solr.common.util.Utils;
|
import org.apache.solr.common.util.Utils;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
|
@ -116,12 +116,7 @@ public class MultiThreadedOCPTest extends AbstractFullDistribZkTestBase {
|
||||||
private void testParallelCollectionAPICalls() throws IOException, SolrServerException {
|
private void testParallelCollectionAPICalls() throws IOException, SolrServerException {
|
||||||
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
||||||
for(int i = 1 ; i <= NUM_COLLECTIONS ; i++) {
|
for(int i = 1 ; i <= NUM_COLLECTIONS ; i++) {
|
||||||
new Create()
|
CollectionAdminRequest.createCollection("ocptest" + i,"conf1",4,1).processAsync(String.valueOf(i), client);
|
||||||
.setCollectionName("ocptest" + i)
|
|
||||||
.setNumShards(4)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.setAsyncId(String.valueOf(i))
|
|
||||||
.process(client);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean pass = false;
|
boolean pass = false;
|
||||||
|
@ -158,12 +153,8 @@ public class MultiThreadedOCPTest extends AbstractFullDistribZkTestBase {
|
||||||
"/overseer/collection-queue-work", new Overseer.Stats());
|
"/overseer/collection-queue-work", new Overseer.Stats());
|
||||||
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
||||||
|
|
||||||
Create createCollectionRequest = new Create()
|
Create createCollectionRequest = CollectionAdminRequest.createCollection("ocptest_shardsplit","conf1",4,1);
|
||||||
.setCollectionName("ocptest_shardsplit")
|
createCollectionRequest.processAsync("1000",client);
|
||||||
.setNumShards(4)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.setAsyncId("1000");
|
|
||||||
createCollectionRequest.process(client);
|
|
||||||
|
|
||||||
distributedQueue.offer(Utils.toJSON(Utils.makeMap(
|
distributedQueue.offer(Utils.toJSON(Utils.makeMap(
|
||||||
"collection", "ocptest_shardsplit",
|
"collection", "ocptest_shardsplit",
|
||||||
|
@ -215,36 +206,21 @@ public class MultiThreadedOCPTest extends AbstractFullDistribZkTestBase {
|
||||||
|
|
||||||
private void testDeduplicationOfSubmittedTasks() throws IOException, SolrServerException {
|
private void testDeduplicationOfSubmittedTasks() throws IOException, SolrServerException {
|
||||||
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
||||||
new Create()
|
CollectionAdminRequest.createCollection("ocptest_shardsplit2","conf1",4,1).processAsync("3000",client);
|
||||||
.setCollectionName("ocptest_shardsplit2")
|
|
||||||
.setNumShards(4)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.setAsyncId("3000")
|
|
||||||
.process(client);
|
|
||||||
|
|
||||||
SplitShard splitShardRequest = new SplitShard()
|
SplitShard splitShardRequest = CollectionAdminRequest.splitShard("ocptest_shardsplit2").setShardName(SHARD1);
|
||||||
.setCollectionName("ocptest_shardsplit2")
|
splitShardRequest.processAsync("3001",client);
|
||||||
.setShardName(SHARD1)
|
|
||||||
.setAsyncId("3001");
|
splitShardRequest = CollectionAdminRequest.splitShard("ocptest_shardsplit2").setShardName(SHARD2);
|
||||||
splitShardRequest.process(client);
|
splitShardRequest.processAsync("3002",client);
|
||||||
|
|
||||||
splitShardRequest = new SplitShard()
|
|
||||||
.setCollectionName("ocptest_shardsplit2")
|
|
||||||
.setShardName(SHARD2)
|
|
||||||
.setAsyncId("3002");
|
|
||||||
splitShardRequest.process(client);
|
|
||||||
|
|
||||||
// Now submit another task with the same id. At this time, hopefully the previous 3002 should still be in the queue.
|
// Now submit another task with the same id. At this time, hopefully the previous 3002 should still be in the queue.
|
||||||
splitShardRequest = new SplitShard()
|
expectThrows(SolrServerException.class, () -> {
|
||||||
.setCollectionName("ocptest_shardsplit2")
|
CollectionAdminRequest.splitShard("ocptest_shardsplit2").setShardName(SHARD1).processAsync("3002",client);
|
||||||
.setShardName(SHARD1)
|
// more helpful assertion failure
|
||||||
.setAsyncId("3002");
|
fail("Duplicate request was supposed to exist but wasn't found. De-duplication of submitted task failed.");
|
||||||
CollectionAdminResponse response = splitShardRequest.process(client);
|
});
|
||||||
|
|
||||||
NamedList r = response.getResponse();
|
|
||||||
assertEquals("Duplicate request was supposed to exist but wasn't found. De-duplication of submitted task failed.",
|
|
||||||
"Task with the same requestid already exists.", r.get("error"));
|
|
||||||
|
|
||||||
for (int i = 3001; i <= 3002; i++) {
|
for (int i = 3001; i <= 3002; i++) {
|
||||||
final RequestStatusState state = getRequestStateAfterCompletion(i + "", REQUEST_STATUS_TIMEOUT, client);
|
final RequestStatusState state = getRequestStateAfterCompletion(i + "", REQUEST_STATUS_TIMEOUT, client);
|
||||||
assertSame("Task " + i + " did not complete, final state: " + state, RequestStatusState.COMPLETED, state);
|
assertSame("Task " + i + " did not complete, final state: " + state, RequestStatusState.COMPLETED, state);
|
||||||
|
@ -271,11 +247,8 @@ public class MultiThreadedOCPTest extends AbstractFullDistribZkTestBase {
|
||||||
indexThread.start();
|
indexThread.start();
|
||||||
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
||||||
|
|
||||||
SplitShard splitShardRequest = new SplitShard()
|
SplitShard splitShardRequest = CollectionAdminRequest.splitShard("collection1").setShardName(SHARD1);
|
||||||
.setCollectionName("collection1")
|
splitShardRequest.processAsync("2000",client);
|
||||||
.setShardName(SHARD1)
|
|
||||||
.setAsyncId("2000");
|
|
||||||
splitShardRequest.process(client);
|
|
||||||
|
|
||||||
RequestStatusState state = getRequestState("2000", client);
|
RequestStatusState state = getRequestState("2000", client);
|
||||||
while (state == RequestStatusState.SUBMITTED) {
|
while (state == RequestStatusState.SUBMITTED) {
|
||||||
|
|
|
@ -65,7 +65,9 @@ public class ReplaceNodeTest extends SolrCloudTestCase {
|
||||||
String emptyNode = l.remove(0);
|
String emptyNode = l.remove(0);
|
||||||
String node2bdecommissioned = l.get(0);
|
String node2bdecommissioned = l.get(0);
|
||||||
CollectionAdminRequest.Create create;
|
CollectionAdminRequest.Create create;
|
||||||
create = pickRandom(CollectionAdminRequest.createCollection(coll, "conf1", 5, 2),
|
// NOTE: always using the createCollection that takes in 'int' for all types of replicas, so we never
|
||||||
|
// have to worry about null checking when comparing the Create command with the final Slices
|
||||||
|
create = pickRandom(CollectionAdminRequest.createCollection(coll, "conf1", 5, 2,0,0),
|
||||||
CollectionAdminRequest.createCollection(coll, "conf1", 5, 1,1,0),
|
CollectionAdminRequest.createCollection(coll, "conf1", 5, 1,1,0),
|
||||||
CollectionAdminRequest.createCollection(coll, "conf1", 5, 0,1,1),
|
CollectionAdminRequest.createCollection(coll, "conf1", 5, 0,1,1),
|
||||||
CollectionAdminRequest.createCollection(coll, "conf1", 5, 1,0,1),
|
CollectionAdminRequest.createCollection(coll, "conf1", 5, 1,0,1),
|
||||||
|
|
|
@ -101,9 +101,7 @@ public class ReplicationFactorTest extends AbstractFullDistribZkTestBase {
|
||||||
CollectionAdminResponse resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
CollectionAdminResponse resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
||||||
|
|
||||||
if (resp.getResponse().get("failure") != null) {
|
if (resp.getResponse().get("failure") != null) {
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
CollectionAdminRequest.deleteCollection(testCollectionName).process(cloudClient);
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
|
||||||
|
|
||||||
resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
||||||
|
|
||||||
|
|
|
@ -70,7 +70,7 @@ public class RollingRestartTest extends AbstractFullDistribZkTestBase {
|
||||||
int n = random().nextInt(getShardCount());
|
int n = random().nextInt(getShardCount());
|
||||||
String nodeName = cloudJettys.get(n).nodeName;
|
String nodeName = cloudJettys.get(n).nodeName;
|
||||||
log.info("Chose {} as overseer designate", nodeName);
|
log.info("Chose {} as overseer designate", nodeName);
|
||||||
new CollectionAdminRequest.AddRole().setRole("overseer").setNode(nodeName).process(cloudClient);
|
CollectionAdminRequest.addRole(nodeName,"overseer").process(cloudClient);
|
||||||
designates.add(nodeName);
|
designates.add(nodeName);
|
||||||
designateJettys.add(cloudJettys.get(n));
|
designateJettys.add(cloudJettys.get(n));
|
||||||
}
|
}
|
||||||
|
|
|
@ -523,16 +523,12 @@ public class ShardSplitTest extends BasicDistributedZkTest {
|
||||||
|
|
||||||
log.info("Starting testSplitShardWithRule");
|
log.info("Starting testSplitShardWithRule");
|
||||||
String collectionName = "shardSplitWithRule";
|
String collectionName = "shardSplitWithRule";
|
||||||
CollectionAdminRequest.Create createRequest = new CollectionAdminRequest.Create()
|
CollectionAdminRequest.Create createRequest = CollectionAdminRequest.createCollection(collectionName,1,2)
|
||||||
.setCollectionName(collectionName)
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setRule("shard:*,replica:<2,node:*");
|
.setRule("shard:*,replica:<2,node:*");
|
||||||
CollectionAdminResponse response = createRequest.process(cloudClient);
|
CollectionAdminResponse response = createRequest.process(cloudClient);
|
||||||
assertEquals(0, response.getStatus());
|
assertEquals(0, response.getStatus());
|
||||||
|
|
||||||
CollectionAdminRequest.SplitShard splitShardRequest = new CollectionAdminRequest.SplitShard()
|
CollectionAdminRequest.SplitShard splitShardRequest = CollectionAdminRequest.splitShard(collectionName)
|
||||||
.setCollectionName(collectionName)
|
|
||||||
.setShardName("shard1");
|
.setShardName("shard1");
|
||||||
response = splitShardRequest.process(cloudClient);
|
response = splitShardRequest.process(cloudClient);
|
||||||
assertEquals(String.valueOf(response.getErrorMessages()), 0, response.getStatus());
|
assertEquals(String.valueOf(response.getErrorMessages()), 0, response.getStatus());
|
||||||
|
|
|
@ -146,12 +146,8 @@ public class SharedFSAutoReplicaFailoverTest extends AbstractFullDistribZkTestBa
|
||||||
// serially
|
// serially
|
||||||
private void testBasics() throws Exception {
|
private void testBasics() throws Exception {
|
||||||
String collection1 = "solrj_collection";
|
String collection1 = "solrj_collection";
|
||||||
Create createCollectionRequest = new Create()
|
Create createCollectionRequest = CollectionAdminRequest.createCollection(collection1,"conf1",2,2)
|
||||||
.setCollectionName(collection1)
|
|
||||||
.setNumShards(2)
|
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setMaxShardsPerNode(2)
|
.setMaxShardsPerNode(2)
|
||||||
.setConfigName("conf1")
|
|
||||||
.setRouterField("myOwnField")
|
.setRouterField("myOwnField")
|
||||||
.setAutoAddReplicas(true);
|
.setAutoAddReplicas(true);
|
||||||
CollectionAdminResponse response = createCollectionRequest.process(cloudClient);
|
CollectionAdminResponse response = createCollectionRequest.process(cloudClient);
|
||||||
|
@ -161,12 +157,8 @@ public class SharedFSAutoReplicaFailoverTest extends AbstractFullDistribZkTestBa
|
||||||
waitForRecoveriesToFinish(collection1, false);
|
waitForRecoveriesToFinish(collection1, false);
|
||||||
|
|
||||||
String collection2 = "solrj_collection2";
|
String collection2 = "solrj_collection2";
|
||||||
createCollectionRequest = new Create()
|
createCollectionRequest = CollectionAdminRequest.createCollection(collection2,"conf1",2,2)
|
||||||
.setCollectionName(collection2)
|
|
||||||
.setNumShards(2)
|
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setMaxShardsPerNode(2)
|
.setMaxShardsPerNode(2)
|
||||||
.setConfigName("conf1")
|
|
||||||
.setRouterField("myOwnField")
|
.setRouterField("myOwnField")
|
||||||
.setAutoAddReplicas(false);
|
.setAutoAddReplicas(false);
|
||||||
CollectionAdminResponse response2 = createCollectionRequest.process(getCommonCloudSolrClient());
|
CollectionAdminResponse response2 = createCollectionRequest.process(getCommonCloudSolrClient());
|
||||||
|
@ -177,12 +169,8 @@ public class SharedFSAutoReplicaFailoverTest extends AbstractFullDistribZkTestBa
|
||||||
waitForRecoveriesToFinish(collection2, false);
|
waitForRecoveriesToFinish(collection2, false);
|
||||||
|
|
||||||
String collection3 = "solrj_collection3";
|
String collection3 = "solrj_collection3";
|
||||||
createCollectionRequest = new Create()
|
createCollectionRequest = CollectionAdminRequest.createCollection(collection3,"conf1",5,1)
|
||||||
.setCollectionName(collection3)
|
|
||||||
.setNumShards(5)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setMaxShardsPerNode(1)
|
.setMaxShardsPerNode(1)
|
||||||
.setConfigName("conf1")
|
|
||||||
.setRouterField("myOwnField")
|
.setRouterField("myOwnField")
|
||||||
.setAutoAddReplicas(true);
|
.setAutoAddReplicas(true);
|
||||||
CollectionAdminResponse response3 = createCollectionRequest.process(getCommonCloudSolrClient());
|
CollectionAdminResponse response3 = createCollectionRequest.process(getCommonCloudSolrClient());
|
||||||
|
@ -194,12 +182,8 @@ public class SharedFSAutoReplicaFailoverTest extends AbstractFullDistribZkTestBa
|
||||||
|
|
||||||
// a collection has only 1 replica per a shard
|
// a collection has only 1 replica per a shard
|
||||||
String collection4 = "solrj_collection4";
|
String collection4 = "solrj_collection4";
|
||||||
createCollectionRequest = new Create()
|
createCollectionRequest = CollectionAdminRequest.createCollection(collection4,"conf1",5,1)
|
||||||
.setCollectionName(collection4)
|
|
||||||
.setNumShards(5)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setMaxShardsPerNode(5)
|
.setMaxShardsPerNode(5)
|
||||||
.setConfigName("conf1")
|
|
||||||
.setRouterField("text")
|
.setRouterField("text")
|
||||||
.setAutoAddReplicas(true);
|
.setAutoAddReplicas(true);
|
||||||
CollectionAdminResponse response4 = createCollectionRequest.process(getCommonCloudSolrClient());
|
CollectionAdminResponse response4 = createCollectionRequest.process(getCommonCloudSolrClient());
|
||||||
|
|
|
@ -39,10 +39,7 @@ public class SimpleCollectionCreateDeleteTest extends AbstractFullDistribZkTestB
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
String collectionName = "SimpleCollectionCreateDeleteTest";
|
String collectionName = "SimpleCollectionCreateDeleteTest";
|
||||||
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create()
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(collectionName,1,1)
|
||||||
.setCollectionName(collectionName)
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setCreateNodeSet(overseerNode)
|
.setCreateNodeSet(overseerNode)
|
||||||
.setStateFormat(2);
|
.setStateFormat(2);
|
||||||
|
|
||||||
|
@ -51,17 +48,13 @@ public class SimpleCollectionCreateDeleteTest extends AbstractFullDistribZkTestB
|
||||||
if (request.get("success") != null) {
|
if (request.get("success") != null) {
|
||||||
assertTrue(cloudClient.getZkStateReader().getZkClient().exists(ZkStateReader.COLLECTIONS_ZKNODE + "/" + collectionName, false));
|
assertTrue(cloudClient.getZkStateReader().getZkClient().exists(ZkStateReader.COLLECTIONS_ZKNODE + "/" + collectionName, false));
|
||||||
|
|
||||||
CollectionAdminRequest.Delete delete = new CollectionAdminRequest.Delete();
|
CollectionAdminRequest delete = CollectionAdminRequest.deleteCollection(collectionName);
|
||||||
delete.setCollectionName(collectionName);
|
|
||||||
cloudClient.request(delete);
|
cloudClient.request(delete);
|
||||||
|
|
||||||
assertFalse(cloudClient.getZkStateReader().getZkClient().exists(ZkStateReader.COLLECTIONS_ZKNODE + "/" + collectionName, false));
|
assertFalse(cloudClient.getZkStateReader().getZkClient().exists(ZkStateReader.COLLECTIONS_ZKNODE + "/" + collectionName, false));
|
||||||
|
|
||||||
// create collection again on a node other than the overseer leader
|
// create collection again on a node other than the overseer leader
|
||||||
create = new CollectionAdminRequest.Create()
|
create = CollectionAdminRequest.createCollection(collectionName,1,1)
|
||||||
.setCollectionName(collectionName)
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setCreateNodeSet(notOverseerNode)
|
.setCreateNodeSet(notOverseerNode)
|
||||||
.setStateFormat(2);
|
.setStateFormat(2);
|
||||||
request = create.process(cloudClient).getResponse();
|
request = create.process(cloudClient).getResponse();
|
||||||
|
|
|
@ -185,13 +185,7 @@ public class TestCollectionAPI extends ReplicaPropertiesBase {
|
||||||
String cname = "clusterStatusZNodeVersion";
|
String cname = "clusterStatusZNodeVersion";
|
||||||
try (CloudSolrClient client = createCloudClient(null)) {
|
try (CloudSolrClient client = createCloudClient(null)) {
|
||||||
|
|
||||||
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create()
|
CollectionAdminRequest.createCollection(cname,"conf1",1,1).setMaxShardsPerNode(1).process(client);
|
||||||
.setCollectionName(cname)
|
|
||||||
.setMaxShardsPerNode(1)
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setConfigName("conf1");
|
|
||||||
create.process(client);
|
|
||||||
|
|
||||||
waitForRecoveriesToFinish(cname, true);
|
waitForRecoveriesToFinish(cname, true);
|
||||||
|
|
||||||
|
@ -213,9 +207,7 @@ public class TestCollectionAPI extends ReplicaPropertiesBase {
|
||||||
Integer znodeVersion = (Integer) collection.get("znodeVersion");
|
Integer znodeVersion = (Integer) collection.get("znodeVersion");
|
||||||
assertNotNull(znodeVersion);
|
assertNotNull(znodeVersion);
|
||||||
|
|
||||||
CollectionAdminRequest.AddReplica addReplica = new CollectionAdminRequest.AddReplica()
|
CollectionAdminRequest.AddReplica addReplica = CollectionAdminRequest.addReplicaToShard(cname, "shard1");
|
||||||
.setCollectionName(cname)
|
|
||||||
.setShardName("shard1");
|
|
||||||
addReplica.process(client);
|
addReplica.process(client);
|
||||||
|
|
||||||
waitForRecoveriesToFinish(cname, true);
|
waitForRecoveriesToFinish(cname, true);
|
||||||
|
@ -628,13 +620,7 @@ public class TestCollectionAPI extends ReplicaPropertiesBase {
|
||||||
try (CloudSolrClient client = createCloudClient(null)) {
|
try (CloudSolrClient client = createCloudClient(null)) {
|
||||||
client.connect();
|
client.connect();
|
||||||
|
|
||||||
new CollectionAdminRequest.Create()
|
CollectionAdminRequest.createCollection("testClusterStateMigration","conf1",1,1).setStateFormat(1).process(client);
|
||||||
.setCollectionName("testClusterStateMigration")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setConfigName("conf1")
|
|
||||||
.setStateFormat(1)
|
|
||||||
.process(client);
|
|
||||||
|
|
||||||
waitForRecoveriesToFinish("testClusterStateMigration", true);
|
waitForRecoveriesToFinish("testClusterStateMigration", true);
|
||||||
|
|
||||||
|
@ -647,9 +633,7 @@ public class TestCollectionAPI extends ReplicaPropertiesBase {
|
||||||
}
|
}
|
||||||
client.commit("testClusterStateMigration");
|
client.commit("testClusterStateMigration");
|
||||||
|
|
||||||
new CollectionAdminRequest.MigrateClusterState()
|
CollectionAdminRequest.migrateCollectionFormat("testClusterStateMigration").process(client);
|
||||||
.setCollectionName("testClusterStateMigration")
|
|
||||||
.process(client);
|
|
||||||
|
|
||||||
client.getZkStateReader().forceUpdateCollection("testClusterStateMigration");
|
client.getZkStateReader().forceUpdateCollection("testClusterStateMigration");
|
||||||
|
|
||||||
|
|
|
@ -73,17 +73,11 @@ public class TestRandomRequestDistribution extends AbstractFullDistribZkTestBase
|
||||||
*/
|
*/
|
||||||
private void testRequestTracking() throws Exception {
|
private void testRequestTracking() throws Exception {
|
||||||
|
|
||||||
new CollectionAdminRequest.Create()
|
CollectionAdminRequest.createCollection("a1x2",1,2)
|
||||||
.setCollectionName("a1x2")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setCreateNodeSet(nodeNames.get(0) + ',' + nodeNames.get(1))
|
.setCreateNodeSet(nodeNames.get(0) + ',' + nodeNames.get(1))
|
||||||
.process(cloudClient);
|
.process(cloudClient);
|
||||||
|
|
||||||
new CollectionAdminRequest.Create()
|
CollectionAdminRequest.createCollection("b1x1",1,1)
|
||||||
.setCollectionName("b1x1")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(1)
|
|
||||||
.setCreateNodeSet(nodeNames.get(2))
|
.setCreateNodeSet(nodeNames.get(2))
|
||||||
.process(cloudClient);
|
.process(cloudClient);
|
||||||
|
|
||||||
|
@ -134,10 +128,7 @@ public class TestRandomRequestDistribution extends AbstractFullDistribZkTestBase
|
||||||
private void testQueryAgainstDownReplica() throws Exception {
|
private void testQueryAgainstDownReplica() throws Exception {
|
||||||
|
|
||||||
log.info("Creating collection 'football' with 1 shard and 2 replicas");
|
log.info("Creating collection 'football' with 1 shard and 2 replicas");
|
||||||
new CollectionAdminRequest.Create()
|
CollectionAdminRequest.createCollection("football",1,2)
|
||||||
.setCollectionName("football")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(2)
|
|
||||||
.setCreateNodeSet(nodeNames.get(0) + ',' + nodeNames.get(1))
|
.setCreateNodeSet(nodeNames.get(0) + ',' + nodeNames.get(1))
|
||||||
.process(cloudClient);
|
.process(cloudClient);
|
||||||
|
|
||||||
|
|
|
@ -72,11 +72,7 @@ public class TestRequestForwarding extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
private void createCollection(String name, String config) throws Exception {
|
private void createCollection(String name, String config) throws Exception {
|
||||||
CollectionAdminResponse response;
|
CollectionAdminResponse response;
|
||||||
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create();
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(name,config,2,1);
|
||||||
create.setConfigName(config);
|
|
||||||
create.setCollectionName(name);
|
|
||||||
create.setNumShards(2);
|
|
||||||
create.setReplicationFactor(1);
|
|
||||||
create.setMaxShardsPerNode(1);
|
create.setMaxShardsPerNode(1);
|
||||||
response = create.process(solrCluster.getSolrClient());
|
response = create.process(solrCluster.getSolrClient());
|
||||||
|
|
||||||
|
|
|
@ -174,10 +174,7 @@ public class TestSolrCloudWithKerberosAlt extends LuceneTestCase {
|
||||||
String configName = "solrCloudCollectionConfig";
|
String configName = "solrCloudCollectionConfig";
|
||||||
miniCluster.uploadConfigSet(SolrTestCaseJ4.TEST_PATH().resolve("collection1/conf"), configName);
|
miniCluster.uploadConfigSet(SolrTestCaseJ4.TEST_PATH().resolve("collection1/conf"), configName);
|
||||||
|
|
||||||
CollectionAdminRequest.Create createRequest = new CollectionAdminRequest.Create();
|
CollectionAdminRequest.Create createRequest = CollectionAdminRequest.createCollection(collectionName,NUM_SHARDS,REPLICATION_FACTOR);
|
||||||
createRequest.setCollectionName(collectionName);
|
|
||||||
createRequest.setNumShards(NUM_SHARDS);
|
|
||||||
createRequest.setReplicationFactor(REPLICATION_FACTOR);
|
|
||||||
Properties properties = new Properties();
|
Properties properties = new Properties();
|
||||||
properties.put(CoreDescriptor.CORE_CONFIG, "solrconfig-tlog.xml");
|
properties.put(CoreDescriptor.CORE_CONFIG, "solrconfig-tlog.xml");
|
||||||
properties.put("solr.tests.maxBufferedDocs", "100000");
|
properties.put("solr.tests.maxBufferedDocs", "100000");
|
||||||
|
@ -216,9 +213,7 @@ public class TestSolrCloudWithKerberosAlt extends LuceneTestCase {
|
||||||
assertEquals(1, rsp.getResults().getNumFound());
|
assertEquals(1, rsp.getResults().getNumFound());
|
||||||
|
|
||||||
// delete the collection we created earlier
|
// delete the collection we created earlier
|
||||||
CollectionAdminRequest.Delete deleteRequest = new CollectionAdminRequest.Delete();
|
CollectionAdminRequest.deleteCollection(collectionName).process(cloudSolrClient);
|
||||||
deleteRequest.setCollectionName(collectionName);
|
|
||||||
deleteRequest.process(cloudSolrClient);
|
|
||||||
|
|
||||||
AbstractDistribZkTestBase.waitForCollectionToDisappear(collectionName, zkStateReader, true, true, 330);
|
AbstractDistribZkTestBase.waitForCollectionToDisappear(collectionName, zkStateReader, true, true, 330);
|
||||||
}
|
}
|
||||||
|
|
|
@ -173,7 +173,7 @@ public class TestSolrCloudWithSecureImpersonation extends SolrTestCaseJ4 {
|
||||||
|
|
||||||
private void create1ShardCollection(String name, String config, MiniSolrCloudCluster solrCluster) throws Exception {
|
private void create1ShardCollection(String name, String config, MiniSolrCloudCluster solrCluster) throws Exception {
|
||||||
CollectionAdminResponse response;
|
CollectionAdminResponse response;
|
||||||
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create() {
|
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create(name,config,1,1,0,0) {
|
||||||
@Override
|
@Override
|
||||||
public SolrParams getParams() {
|
public SolrParams getParams() {
|
||||||
ModifiableSolrParams msp = new ModifiableSolrParams(super.getParams());
|
ModifiableSolrParams msp = new ModifiableSolrParams(super.getParams());
|
||||||
|
@ -181,10 +181,6 @@ public class TestSolrCloudWithSecureImpersonation extends SolrTestCaseJ4 {
|
||||||
return msp;
|
return msp;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
create.setConfigName(config);
|
|
||||||
create.setCollectionName(name);
|
|
||||||
create.setNumShards(1);
|
|
||||||
create.setReplicationFactor(1);
|
|
||||||
create.setMaxShardsPerNode(1);
|
create.setMaxShardsPerNode(1);
|
||||||
response = create.process(solrCluster.getSolrClient());
|
response = create.process(solrCluster.getSolrClient());
|
||||||
|
|
||||||
|
|
|
@ -62,10 +62,7 @@ public class TestBlobHandler extends AbstractFullDistribZkTestBase {
|
||||||
|
|
||||||
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
try (SolrClient client = createNewSolrClient("", getBaseUrl((HttpSolrClient) clients.get(0)))) {
|
||||||
CollectionAdminResponse response1;
|
CollectionAdminResponse response1;
|
||||||
CollectionAdminRequest.Create createCollectionRequest = new CollectionAdminRequest.Create()
|
CollectionAdminRequest.Create createCollectionRequest = CollectionAdminRequest.createCollection(".system",1,2);
|
||||||
.setCollectionName(".system")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(2);
|
|
||||||
response1 = createCollectionRequest.process(client);
|
response1 = createCollectionRequest.process(client);
|
||||||
assertEquals(0, response1.getStatus());
|
assertEquals(0, response1.getStatus());
|
||||||
assertTrue(response1.isSuccess());
|
assertTrue(response1.isSuccess());
|
||||||
|
@ -119,10 +116,7 @@ public class TestBlobHandler extends AbstractFullDistribZkTestBase {
|
||||||
|
|
||||||
public static void createSystemCollection(SolrClient client) throws SolrServerException, IOException {
|
public static void createSystemCollection(SolrClient client) throws SolrServerException, IOException {
|
||||||
CollectionAdminResponse response1;
|
CollectionAdminResponse response1;
|
||||||
CollectionAdminRequest.Create createCollectionRequest = new CollectionAdminRequest.Create()
|
CollectionAdminRequest.Create createCollectionRequest = CollectionAdminRequest.createCollection(".system",1,2);
|
||||||
.setCollectionName(".system")
|
|
||||||
.setNumShards(1)
|
|
||||||
.setReplicationFactor(2);
|
|
||||||
response1 = createCollectionRequest.process(client);
|
response1 = createCollectionRequest.process(client);
|
||||||
assertEquals(0, response1.getStatus());
|
assertEquals(0, response1.getStatus());
|
||||||
assertTrue(response1.isSuccess());
|
assertTrue(response1.isSuccess());
|
||||||
|
|
|
@ -196,20 +196,11 @@ public class TestDistribIDF extends SolrTestCaseJ4 {
|
||||||
private void createCollection(String name, String config, String router) throws Exception {
|
private void createCollection(String name, String config, String router) throws Exception {
|
||||||
CollectionAdminResponse response;
|
CollectionAdminResponse response;
|
||||||
if (router.equals(ImplicitDocRouter.NAME)) {
|
if (router.equals(ImplicitDocRouter.NAME)) {
|
||||||
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create();
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollectionWithImplicitRouter(name,config,"a,b,c",1);
|
||||||
create.setConfigName(config);
|
|
||||||
create.setCollectionName(name);
|
|
||||||
create.setReplicationFactor(1);
|
|
||||||
create.setMaxShardsPerNode(1);
|
create.setMaxShardsPerNode(1);
|
||||||
create.setRouterName(router);
|
|
||||||
create.setShards("a,b,c");
|
|
||||||
response = create.process(solrCluster.getSolrClient());
|
response = create.process(solrCluster.getSolrClient());
|
||||||
} else {
|
} else {
|
||||||
CollectionAdminRequest.Create create = new CollectionAdminRequest.Create();
|
CollectionAdminRequest.Create create = CollectionAdminRequest.createCollection(name,config,2,1);
|
||||||
create.setConfigName(config);
|
|
||||||
create.setCollectionName(name);
|
|
||||||
create.setNumShards(2);
|
|
||||||
create.setReplicationFactor(1);
|
|
||||||
create.setMaxShardsPerNode(1);
|
create.setMaxShardsPerNode(1);
|
||||||
response = create.process(solrCluster.getSolrClient());
|
response = create.process(solrCluster.getSolrClient());
|
||||||
}
|
}
|
||||||
|
|
|
@ -86,7 +86,7 @@ copy_snapshot_files() {
|
||||||
for shardId in $(hdfs dfs -stat "%n" "${copylisting_dir_path}/*"); do
|
for shardId in $(hdfs dfs -stat "%n" "${copylisting_dir_path}/*"); do
|
||||||
oPath="${destPath}/${snapshotName}/snapshot.${shardId}"
|
oPath="${destPath}/${snapshotName}/snapshot.${shardId}"
|
||||||
echo "Copying the index files for ${shardId} to ${oPath}"
|
echo "Copying the index files for ${shardId} to ${oPath}"
|
||||||
${distCpCmd} -f " ${copylisting_dir_path}/${shardId}" "${oPath}" > /dev/null
|
${distCpCmd} -f "${copylisting_dir_path}/${shardId}" "${oPath}" > /dev/null
|
||||||
done
|
done
|
||||||
else
|
else
|
||||||
echo "Directory ${copylisting_dir_path} does not exist."
|
echo "Directory ${copylisting_dir_path} does not exist."
|
||||||
|
|
|
@ -20,7 +20,16 @@
|
||||||
|
|
||||||
A `codecFactory` can be specified in `solrconfig.xml` to determine which Lucene {lucene-javadocs}/core/org/apache/lucene/codecs/Codec.html[`Codec`] is used when writing the index to disk.
|
A `codecFactory` can be specified in `solrconfig.xml` to determine which Lucene {lucene-javadocs}/core/org/apache/lucene/codecs/Codec.html[`Codec`] is used when writing the index to disk.
|
||||||
|
|
||||||
If not specified, Lucene's default codec is implicitly used, but a {solr-javadocs}/solr-core/org/apache/solr/core/SchemaCodecFactory.html[`solr.SchemaCodecFactory`] is also available which supports 2 key features:
|
If not specified, Lucene's default codec is implicitly used.
|
||||||
|
|
||||||
|
There are two alternatives to Lucene's default codec:
|
||||||
|
|
||||||
|
. {solr-javadocs}/solr-core/org/apache/solr/core/SchemaCodecFactory.html[`solr.SchemaCodecFactory`]
|
||||||
|
. {solr-javadocs}/solr-core/org/apache/solr/core/SimpleTextCodecFactory.html[`solr.SimpleTextCodecFactory`]
|
||||||
|
|
||||||
|
=== solr.SchemaCodecFactory
|
||||||
|
|
||||||
|
`solr.SchemaCodecFactory` supports 2 key features:
|
||||||
|
|
||||||
* Schema based per-fieldtype configuration for `docValuesFormat` and `postingsFormat` - see the <<field-type-definitions-and-properties.adoc#field-type-properties,Field Type Properties>> section for more details.
|
* Schema based per-fieldtype configuration for `docValuesFormat` and `postingsFormat` - see the <<field-type-definitions-and-properties.adoc#field-type-properties,Field Type Properties>> section for more details.
|
||||||
* A `compressionMode` option:
|
* A `compressionMode` option:
|
||||||
|
@ -35,3 +44,16 @@ Example:
|
||||||
<str name="compressionMode">BEST_COMPRESSION</str>
|
<str name="compressionMode">BEST_COMPRESSION</str>
|
||||||
</codecFactory>
|
</codecFactory>
|
||||||
----
|
----
|
||||||
|
|
||||||
|
=== solr.SimpleTextCodecFactory
|
||||||
|
|
||||||
|
This factory for Lucene's `SimpleTextCodec` produces a plain text human-readable index format.
|
||||||
|
|
||||||
|
CAUTION: *FOR RECREATIONAL USE ONLY*. This codec should never be used in production. `SimpleTextCodec` is relatively slow and takes up a large amount of disk space. Its use should be limited to educational and debugging purposes.
|
||||||
|
|
||||||
|
Example:
|
||||||
|
|
||||||
|
[source,xml]
|
||||||
|
----
|
||||||
|
<codecFactory class="solr.SimpleTextCodecFactory"/>
|
||||||
|
----
|
||||||
|
|
|
@ -119,7 +119,7 @@ The RELOAD action loads a new core from the configuration of an existing, regist
|
||||||
|
|
||||||
`admin/cores?action=RELOAD&core=_core-name_`
|
`admin/cores?action=RELOAD&core=_core-name_`
|
||||||
|
|
||||||
This is useful when you've made changes to a Solr core's configuration on disk, such as adding new field definitions. Calling the RELOAD action lets you apply the new configuration without having to restart the Web container.
|
This is useful when you've made changes to a Solr core's configuration on disk, such as adding new field definitions. Calling the RELOAD action lets you apply the new configuration without having to restart Solr.
|
||||||
|
|
||||||
[IMPORTANT]
|
[IMPORTANT]
|
||||||
====
|
====
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
|
|
||||||
Solr can encrypt communications to and from clients, and between nodes in SolrCloud mode, with SSL.
|
Solr can encrypt communications to and from clients, and between nodes in SolrCloud mode, with SSL.
|
||||||
|
|
||||||
This section describes enabling SSL with the example Jetty server using a self-signed certificate.
|
This section describes enabling SSL using a self-signed certificate.
|
||||||
|
|
||||||
For background on SSL certificates and keys, see http://www.tldp.org/HOWTO/SSL-Certificates-HOWTO/.
|
For background on SSL certificates and keys, see http://www.tldp.org/HOWTO/SSL-Certificates-HOWTO/.
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@ This section will describe the default `solr.xml` file included with Solr and ho
|
||||||
[[Formatofsolr.xml-Definingsolr.xml]]
|
[[Formatofsolr.xml-Definingsolr.xml]]
|
||||||
== Defining solr.xml
|
== Defining solr.xml
|
||||||
|
|
||||||
You can find `solr.xml` in your Solr Home directory or in Zookeeper. The default `solr.xml` file looks like this:
|
You can find `solr.xml` in your `$SOLR_HOME` directory (usually `server/solr`) in standalone mode or in Zookeeper when using SolrCloud. The default `solr.xml` file looks like this:
|
||||||
|
|
||||||
[source,xml]
|
[source,xml]
|
||||||
----
|
----
|
||||||
|
@ -66,17 +66,17 @@ There are no attributes that you can specify in the `<solr>` tag, which is the r
|
||||||
|`collectionsHandler` |As above, for custom CollectionsHandler implementations.
|
|`collectionsHandler` |As above, for custom CollectionsHandler implementations.
|
||||||
| `infoHandler` |As above, for custom InfoHandler implementations.
|
| `infoHandler` |As above, for custom InfoHandler implementations.
|
||||||
|`coreLoadThreads` |Specifies the number of threads that will be assigned to load cores in parallel.
|
|`coreLoadThreads` |Specifies the number of threads that will be assigned to load cores in parallel.
|
||||||
|`coreRootDirectory` |The root of the core discovery tree, defaults to SOLR_HOME.
|
|`coreRootDirectory` |The root of the core discovery tree, defaults to `$SOLR_HOME`.
|
||||||
|`managementPath` |Currently non-operational.
|
|`managementPath` |Currently non-operational.
|
||||||
|`sharedLib` |Specifies the path to a common library directory that will be shared across all cores. Any JAR files in this directory will be added to the search path for Solr plugins. This path is relative to the top-level container's Solr Home. Custom handlers may be placed in this directory
|
|`sharedLib` |Specifies the path to a common library directory that will be shared across all cores. Any JAR files in this directory will be added to the search path for Solr plugins. This path is relative to `$SOLR_HOME`. Custom handlers may be placed in this directory.
|
||||||
|`shareSchema` |This attribute, when set to true, ensures that the multiple cores pointing to the same Schema resource file will be referring to the same IndexSchema Object. Sharing the IndexSchema Object makes loading the core faster. If you use this feature, make sure that no core-specific property is used in your Schema file.
|
|`shareSchema` |This attribute, when set to true, ensures that the multiple cores pointing to the same Schema resource file will be referring to the same IndexSchema Object. Sharing the IndexSchema Object makes loading the core faster. If you use this feature, make sure that no core-specific property is used in your Schema file.
|
||||||
|`transientCacheSize` |Defines how many cores with transient=true that can be loaded before swapping the least recently used core for a new core.
|
|`transientCacheSize` |Defines how many cores with transient=true that can be loaded before swapping the least recently used core for a new core.
|
||||||
|`configSetBaseDir` |The directory under which configsets for solr cores can be found. Defaults to SOLR_HOME/configsets
|
|`configSetBaseDir` |The directory under which configsets for Solr cores can be found. Defaults to `$SOLR_HOME/configsets`.
|
||||||
|===
|
|===
|
||||||
|
|
||||||
==== The `<solrcloud>` element
|
==== The `<solrcloud>` Element
|
||||||
|
|
||||||
This element defines several parameters that relate so SolrCloud. This section is ignored unless the solr instance is started with either `-DzkRun` or `-DzkHost`
|
This element defines several parameters that relate so SolrCloud. This section is ignored unless theSolr instance is started with either `-DzkRun` or `-DzkHost`
|
||||||
|
|
||||||
// TODO: Change column width to %autowidth.spread when https://github.com/asciidoctor/asciidoctor-pdf/issues/599 is fixed
|
// TODO: Change column width to %autowidth.spread when https://github.com/asciidoctor/asciidoctor-pdf/issues/599 is fixed
|
||||||
|
|
||||||
|
@ -96,18 +96,18 @@ This element defines several parameters that relate so SolrCloud. This section i
|
||||||
|`zkCredentialsProvider` & ` zkACLProvider` |Optional parameters that can be specified if you are using <<zookeeper-access-control.adoc#zookeeper-access-control,ZooKeeper Access Control>>.
|
|`zkCredentialsProvider` & ` zkACLProvider` |Optional parameters that can be specified if you are using <<zookeeper-access-control.adoc#zookeeper-access-control,ZooKeeper Access Control>>.
|
||||||
|===
|
|===
|
||||||
|
|
||||||
==== The `<logging>` element
|
==== The `<logging>` Element
|
||||||
|
|
||||||
// TODO: Change column width to %autowidth.spread when https://github.com/asciidoctor/asciidoctor-pdf/issues/599 is fixed
|
// TODO: Change column width to %autowidth.spread when https://github.com/asciidoctor/asciidoctor-pdf/issues/599 is fixed
|
||||||
|
|
||||||
[cols="30,70",options="header"]
|
[cols="30,70",options="header"]
|
||||||
|===
|
|===
|
||||||
|Node |Description
|
|Node |Description
|
||||||
|`class` |The class to use for logging. The corresponding JAR file must be available to solr, perhaps through a `<lib>` directive in solrconfig.xml.
|
|`class` |The class to use for logging. The corresponding JAR file must be available to Solr, perhaps through a `<lib>` directive in `solrconfig.xml`.
|
||||||
|`enabled` |true/false - whether to enable logging or not.
|
|`enabled` |true/false - whether to enable logging or not.
|
||||||
|===
|
|===
|
||||||
|
|
||||||
===== The `<logging><watcher>` element
|
===== The `<logging><watcher>` Element
|
||||||
|
|
||||||
// TODO: Change column width to %autowidth.spread when https://github.com/asciidoctor/asciidoctor-pdf/issues/599 is fixed
|
// TODO: Change column width to %autowidth.spread when https://github.com/asciidoctor/asciidoctor-pdf/issues/599 is fixed
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ This element defines several parameters that relate so SolrCloud. This section i
|
||||||
|`threshold` |The logging level above which your particular logging implementation will record. For example when using log4j one might specify DEBUG, WARN, INFO, etc.
|
|`threshold` |The logging level above which your particular logging implementation will record. For example when using log4j one might specify DEBUG, WARN, INFO, etc.
|
||||||
|===
|
|===
|
||||||
|
|
||||||
==== The `<shardHandlerFactory>` element
|
==== The `<shardHandlerFactory>` Element
|
||||||
|
|
||||||
Custom shard handlers can be defined in `solr.xml` if you wish to create a custom shard handler.
|
Custom shard handlers can be defined in `solr.xml` if you wish to create a custom shard handler.
|
||||||
|
|
||||||
|
@ -134,8 +134,8 @@ Since this is a custom shard handler, sub-elements are specific to the implement
|
||||||
[cols="30,70",options="header"]
|
[cols="30,70",options="header"]
|
||||||
|===
|
|===
|
||||||
|Node |Description
|
|Node |Description
|
||||||
|`socketTimeout` |The read timeout for intra-cluster query and administrative requests. The default is the same as the distribUpdateSoTimeout specified in the solrcloud section.
|
|`socketTimeout` |The read timeout for intra-cluster query and administrative requests. The default is the same as the `distribUpdateSoTimeout` specified in the `<solrcloud>` section.
|
||||||
|`connTimeout` |The connection timeout for intra-cluster query and administrative requests. Defaults to the distribUpdateConnTimeout specified in the solrcloud section
|
|`connTimeout` |The connection timeout for intra-cluster query and administrative requests. Defaults to the `distribUpdateConnTimeout` specified in the `<solrcloud>` section
|
||||||
|`urlScheme` |URL scheme to be used in distributed search
|
|`urlScheme` |URL scheme to be used in distributed search
|
||||||
|`maxConnectionsPerHost` |Maximum connections allowed per host. Defaults to 20
|
|`maxConnectionsPerHost` |Maximum connections allowed per host. Defaults to 20
|
||||||
|`maxConnections` |Maximum total connections allowed. Defaults to 10000
|
|`maxConnections` |Maximum total connections allowed. Defaults to 10000
|
||||||
|
|
|
@ -425,7 +425,7 @@ This option is useful if you are running multiple standalone Solr instances on t
|
||||||
|
|
||||||
The `bin/solr` script allows enabling or disabling Basic Authentication, allowing you to configure authentication from the command line.
|
The `bin/solr` script allows enabling or disabling Basic Authentication, allowing you to configure authentication from the command line.
|
||||||
|
|
||||||
Currently, this script only enables Basic Authentication.
|
Currently, this script only enables Basic Authentication, and is only available when using SolrCloud mode.
|
||||||
|
|
||||||
=== Enabling Basic Authentication
|
=== Enabling Basic Authentication
|
||||||
|
|
||||||
|
@ -435,7 +435,7 @@ TIP: For more information about Solr's authentication plugins, see the section <
|
||||||
|
|
||||||
The `bin/solr auth enable` command makes several changes to enable Basic Authentication:
|
The `bin/solr auth enable` command makes several changes to enable Basic Authentication:
|
||||||
|
|
||||||
* Creates a `security.json` file and, if using SolrCloud, uploads it to ZooKeeper. The `security.json` file will look similar to:
|
* Creates a `security.json` file and uploads it to ZooKeeper. The `security.json` file will look similar to:
|
||||||
+
|
+
|
||||||
[source,json]
|
[source,json]
|
||||||
----
|
----
|
||||||
|
@ -484,15 +484,14 @@ When *true*, blocks all unauthenticated users from accessing Solr. This defaults
|
||||||
`-updateIncludeFileOnly`::
|
`-updateIncludeFileOnly`::
|
||||||
When *true*, only the settings in `bin/solr.in.sh` or `bin\solr.in.cmd` will be updated, and `security.json` will not be created.
|
When *true*, only the settings in `bin/solr.in.sh` or `bin\solr.in.cmd` will be updated, and `security.json` will not be created.
|
||||||
|
|
||||||
// TODO 6.6 clarify when this is required
|
|
||||||
`-z`::
|
`-z`::
|
||||||
Defines the ZooKeeper connect string.
|
Defines the ZooKeeper connect string. This is useful if you want to enable authentication before all your Solr nodes have come up.
|
||||||
|
|
||||||
`-d`::
|
`-d`::
|
||||||
Defines the Solr server directory, by default `$SOLR_HOME/server`. It is not common to need to override the default.
|
Defines the Solr server directory, by default `$SOLR_HOME/server`. It is not common to need to override the default, and is only needed if you have customized the `$SOLR_HOME` directory path.
|
||||||
|
|
||||||
`-s`::
|
`-s`::
|
||||||
Defines the location of `solr.solr.home`, which by default is `server/solr`. If you have multiple instances of Solr on the same host, you likely need to define this.
|
Defines the location of `solr.solr.home`, which by default is `server/solr`. If you have multiple instances of Solr on the same host, or if you have customized the `$SOLR_HOME` directory path, you likely need to define this.
|
||||||
|
|
||||||
=== Disabling Basic Authentication
|
=== Disabling Basic Authentication
|
||||||
|
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -17,6 +17,7 @@
|
||||||
package org.apache.solr.client.solrj;
|
package org.apache.solr.client.solrj;
|
||||||
|
|
||||||
import static org.apache.solr.common.params.CoreAdminParams.*;
|
import static org.apache.solr.common.params.CoreAdminParams.*;
|
||||||
|
import static org.apache.solr.common.params.CollectionAdminParams.FLUSH;
|
||||||
|
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
@ -37,135 +38,131 @@ import com.google.common.collect.Sets;
|
||||||
public class CollectionAdminRequestRequiredParamsTest extends LuceneTestCase {
|
public class CollectionAdminRequestRequiredParamsTest extends LuceneTestCase {
|
||||||
|
|
||||||
public void testBalanceShardUnique() {
|
public void testBalanceShardUnique() {
|
||||||
final CollectionAdminRequest.BalanceShardUnique request = new CollectionAdminRequest.BalanceShardUnique()
|
CollectionAdminRequest.BalanceShardUnique request = CollectionAdminRequest.balanceReplicaProperty("foo","prop");
|
||||||
.setCollection("foo")
|
|
||||||
.setPropertyName("prop");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, "property");
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, "property");
|
||||||
|
|
||||||
|
request.setShardUnique(true);
|
||||||
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, "property","shardUnique");
|
||||||
|
|
||||||
|
request.setOnlyActiveNodes(false);
|
||||||
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, "property","shardUnique","onlyactivenodes");
|
||||||
|
|
||||||
|
request.setShardUnique(null);
|
||||||
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, "property","onlyactivenodes");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testClusterProp() {
|
public void testClusterProp() {
|
||||||
final CollectionAdminRequest.ClusterProp request = new CollectionAdminRequest.ClusterProp()
|
CollectionAdminRequest.ClusterProp request = CollectionAdminRequest.setClusterProperty("foo","bar");
|
||||||
.setPropertyName("foo")
|
|
||||||
.setPropertyValue("bar");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, NAME, "val");
|
assertContainsParams(request.getParams(), ACTION, NAME, "val");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testAddRole() {
|
public void testAddRole() {
|
||||||
final CollectionAdminRequest.AddRole request = new CollectionAdminRequest.AddRole()
|
CollectionAdminRequest.AddRole request = CollectionAdminRequest.addRole("node","role");
|
||||||
.setNode("node")
|
|
||||||
.setRole("role");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, "node", "role");
|
assertContainsParams(request.getParams(), ACTION, "node", "role");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testRemoveRole() {
|
public void testRemoveRole() {
|
||||||
final CollectionAdminRequest.RemoveRole request = new CollectionAdminRequest.RemoveRole()
|
CollectionAdminRequest.RemoveRole request = CollectionAdminRequest.removeRole("node","role");
|
||||||
.setNode("node")
|
|
||||||
.setRole("role");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, "node", "role");
|
assertContainsParams(request.getParams(), ACTION, "node", "role");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testAddReplica() {
|
public void testAddReplica() {
|
||||||
// with shard parameter
|
// with shard parameter and "client side" implicit type param
|
||||||
CollectionAdminRequest.AddReplica request = new CollectionAdminRequest.AddReplica()
|
CollectionAdminRequest.AddReplica request = CollectionAdminRequest.addReplicaToShard("collection", "shard");
|
||||||
.setShardName("shard")
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, ZkStateReader.REPLICA_TYPE);
|
||||||
.setCollectionName("collection");
|
|
||||||
|
// with only shard parameter and "server side" implicit type, so no param
|
||||||
|
request = CollectionAdminRequest.addReplicaToShard("collection", "shard", null);
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
||||||
|
|
||||||
// with route parameter
|
// with route parameter
|
||||||
request = new CollectionAdminRequest.AddReplica()
|
request = CollectionAdminRequest.addReplicaByRouteKey("collection","route");
|
||||||
.setRouteKey("route")
|
|
||||||
.setCollectionName("collection");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, ShardParams._ROUTE_);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, ShardParams._ROUTE_);
|
||||||
|
|
||||||
// with type parameter
|
// with explicit type parameter
|
||||||
request = new CollectionAdminRequest.AddReplica()
|
request = CollectionAdminRequest.addReplicaToShard("collection", "shard", Replica.Type.NRT);
|
||||||
.setShardName("shard")
|
|
||||||
.setCollectionName("collection")
|
|
||||||
.setType(Replica.Type.NRT);
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, ZkStateReader.REPLICA_TYPE);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, ZkStateReader.REPLICA_TYPE);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testAddReplicaProp() {
|
public void testAddReplicaProp() {
|
||||||
final CollectionAdminRequest.AddReplicaProp request = new CollectionAdminRequest.AddReplicaProp()
|
final CollectionAdminRequest.AddReplicaProp request = CollectionAdminRequest.addReplicaProperty
|
||||||
.setShardName("shard")
|
("collection", "shard", "replica", "prop", "value");
|
||||||
.setCollectionName("collection")
|
|
||||||
.setReplica("replica")
|
|
||||||
.setPropertyName("prop")
|
|
||||||
.setPropertyValue("value");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, REPLICA, "property", "property.value");
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, REPLICA, "property", "property.value");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testClusterStatus() {
|
public void testClusterStatus() {
|
||||||
final CollectionAdminRequest.ClusterStatus request = new CollectionAdminRequest.ClusterStatus();
|
final CollectionAdminRequest.ClusterStatus request = CollectionAdminRequest.getClusterStatus();
|
||||||
assertContainsParams(request.getParams(), ACTION);
|
assertContainsParams(request.getParams(), ACTION);
|
||||||
|
|
||||||
|
request.setCollectionName("foo");
|
||||||
|
assertContainsParams(request.getParams(), ACTION, COLLECTION);
|
||||||
|
|
||||||
|
request.setShardName("foo");
|
||||||
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
||||||
|
|
||||||
|
request.setRouteKey("foo");
|
||||||
|
request.setShardName(null);
|
||||||
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, ShardParams._ROUTE_);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCreateShard() {
|
public void testCreateShard() {
|
||||||
final CollectionAdminRequest.CreateShard request = new CollectionAdminRequest.CreateShard()
|
final CollectionAdminRequest.CreateShard request = CollectionAdminRequest.createShard("collection","shard");
|
||||||
.setCollectionName("collection")
|
|
||||||
.setShardName("shard");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteReplica() {
|
public void testDeleteReplica() {
|
||||||
final CollectionAdminRequest.DeleteReplica request = new CollectionAdminRequest.DeleteReplica()
|
final CollectionAdminRequest.DeleteReplica request = CollectionAdminRequest.deleteReplica("collection","shard","replica");
|
||||||
.setCollectionName("collection")
|
|
||||||
.setShardName("shard")
|
|
||||||
.setReplica("replica");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, REPLICA);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, REPLICA);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteReplicaProp() {
|
public void testDeleteReplicaProp() {
|
||||||
final CollectionAdminRequest.DeleteReplicaProp request = new CollectionAdminRequest.DeleteReplicaProp()
|
final CollectionAdminRequest.DeleteReplicaProp request = CollectionAdminRequest.deleteReplicaProperty
|
||||||
.setCollectionName("collection")
|
("collection", "shard", "replica", "foo");
|
||||||
.setShardName("shard")
|
|
||||||
.setReplica("replica")
|
|
||||||
.setPropertyName("foo");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, REPLICA, "property");
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD, REPLICA, "property");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteShard() {
|
public void testDeleteShard() {
|
||||||
final CollectionAdminRequest.DeleteShard request = new CollectionAdminRequest.DeleteShard()
|
final CollectionAdminRequest.DeleteShard request = CollectionAdminRequest.deleteShard("collection","shard");
|
||||||
.setCollectionName("collection")
|
|
||||||
.setShardName("shard");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testSplitShard() {
|
public void testSplitShard() {
|
||||||
final CollectionAdminRequest.SplitShard request = new CollectionAdminRequest.SplitShard()
|
final CollectionAdminRequest.SplitShard request = CollectionAdminRequest.splitShard("collection")
|
||||||
.setCollectionName("collection")
|
|
||||||
.setShardName("shard");
|
.setShardName("shard");
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, SHARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCreateCollection() {
|
public void testCreateCollection() {
|
||||||
final CollectionAdminRequest.Create request = new CollectionAdminRequest.Create()
|
// shortest form
|
||||||
.setCollectionName("collection");
|
assertContainsParams(CollectionAdminRequest.createCollection("foo", null, 1, 1).getParams(),
|
||||||
assertContainsParams(request.getParams(), ACTION, NAME);
|
ACTION, NAME, ZkStateReader.NUM_SHARDS_PROP,
|
||||||
|
"replicationFactor", ZkStateReader.NRT_REPLICAS);
|
||||||
|
// shortest form w/ "explicitly" choosing "implicit" router
|
||||||
|
assertContainsParams(CollectionAdminRequest.createCollectionWithImplicitRouter("foo", null, "bar", 1).getParams(),
|
||||||
|
ACTION, NAME, "shards", "router.name",
|
||||||
|
"replicationFactor", ZkStateReader.NRT_REPLICAS);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testReloadCollection() {
|
public void testReloadCollection() {
|
||||||
final CollectionAdminRequest.Reload request = new CollectionAdminRequest.Reload()
|
final CollectionAdminRequest.Reload request = CollectionAdminRequest.reloadCollection("collection");
|
||||||
.setCollectionName("collection");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, NAME);
|
assertContainsParams(request.getParams(), ACTION, NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteCollection() {
|
public void testDeleteCollection() {
|
||||||
final CollectionAdminRequest.Delete request = new CollectionAdminRequest.Delete()
|
final CollectionAdminRequest.Delete request = CollectionAdminRequest.deleteCollection("collection");
|
||||||
.setCollectionName("collection");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, NAME);
|
assertContainsParams(request.getParams(), ACTION, NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCreateAlias() {
|
public void testCreateAlias() {
|
||||||
final CollectionAdminRequest.CreateAlias request = new CollectionAdminRequest.CreateAlias()
|
final CollectionAdminRequest.CreateAlias request = CollectionAdminRequest.createAlias("name","collections");
|
||||||
.setAliasName("name")
|
|
||||||
.setAliasedCollections("collections");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, NAME, "collections");
|
assertContainsParams(request.getParams(), ACTION, NAME, "collections");
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteAlias() {
|
public void testDeleteAlias() {
|
||||||
final CollectionAdminRequest.DeleteAlias request = new CollectionAdminRequest.DeleteAlias()
|
final CollectionAdminRequest.DeleteAlias request = CollectionAdminRequest.deleteAlias("name");
|
||||||
.setAliasName("name");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, NAME);
|
assertContainsParams(request.getParams(), ACTION, NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -175,10 +172,7 @@ public class CollectionAdminRequestRequiredParamsTest extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testMigrate() {
|
public void testMigrate() {
|
||||||
final CollectionAdminRequest.Migrate request = new CollectionAdminRequest.Migrate()
|
final CollectionAdminRequest.Migrate request = CollectionAdminRequest.migrateData("collection","targer","splitKey");
|
||||||
.setCollectionName("collection")
|
|
||||||
.setTargetCollection("target")
|
|
||||||
.setSplitKey("splitKey");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, COLLECTION, "target.collection", "split.key");
|
assertContainsParams(request.getParams(), ACTION, COLLECTION, "target.collection", "split.key");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -188,10 +182,21 @@ public class CollectionAdminRequestRequiredParamsTest extends LuceneTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testRequestStatus() {
|
public void testRequestStatus() {
|
||||||
final CollectionAdminRequest.RequestStatus request = new CollectionAdminRequest.RequestStatus()
|
final CollectionAdminRequest.RequestStatus request = CollectionAdminRequest.requestStatus("request");
|
||||||
.setRequestId("request");
|
|
||||||
assertContainsParams(request.getParams(), ACTION, REQUESTID);
|
assertContainsParams(request.getParams(), ACTION, REQUESTID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testDeleteStatus() {
|
||||||
|
assertContainsParams(CollectionAdminRequest.deleteAsyncId("foo").getParams(),
|
||||||
|
ACTION, REQUESTID);
|
||||||
|
assertContainsParams(CollectionAdminRequest.deleteAllAsyncIds().getParams(),
|
||||||
|
ACTION, FLUSH);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void testForceLeader() {
|
||||||
|
assertContainsParams(CollectionAdminRequest.forceLeaderElection("foo","bar").getParams(),
|
||||||
|
ACTION, COLLECTION, SHARD);
|
||||||
|
}
|
||||||
|
|
||||||
private void assertContainsParams(SolrParams solrParams, String... requiredParams) {
|
private void assertContainsParams(SolrParams solrParams, String... requiredParams) {
|
||||||
final Set<String> requiredParamsSet = Sets.newHashSet(requiredParams);
|
final Set<String> requiredParamsSet = Sets.newHashSet(requiredParams);
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
package org.apache.solr.client.solrj.request;
|
package org.apache.solr.client.solrj.request;
|
||||||
|
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
import org.apache.lucene.util.LuceneTestCase;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.Create;
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.CreateAlias;
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest.CreateAlias;
|
||||||
import org.apache.solr.client.solrj.request.CollectionAdminRequest.CreateShard;
|
import org.apache.solr.client.solrj.request.CollectionAdminRequest.CreateShard;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
@ -30,57 +30,57 @@ public class TestCollectionAdminRequest extends LuceneTestCase {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInvalidCollectionNameRejectedWhenCreatingCollection() {
|
public void testInvalidCollectionNameRejectedWhenCreatingCollection() {
|
||||||
final Create createRequest = new Create();
|
final SolrException e = expectThrows(SolrException.class, () -> {
|
||||||
try {
|
CollectionAdminRequest.createCollection("invalid$collection@name", null, 1, 1);
|
||||||
createRequest.setCollectionName("invalid$collection@name");
|
});
|
||||||
fail();
|
final String exceptionMessage = e.getMessage();
|
||||||
} catch (SolrException e) {
|
assertTrue(exceptionMessage.contains("Invalid collection"));
|
||||||
final String exceptionMessage = e.getMessage();
|
assertTrue(exceptionMessage.contains("invalid$collection@name"));
|
||||||
assertTrue(exceptionMessage.contains("Invalid collection"));
|
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
||||||
assertTrue(exceptionMessage.contains("invalid$collection@name"));
|
|
||||||
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInvalidShardNamesRejectedWhenCreatingCollection() {
|
public void testInvalidShardNamesRejectedWhenCreatingImplicitCollection() {
|
||||||
final Create createRequest = new Create();
|
final SolrException e = expectThrows(SolrException.class, () -> {
|
||||||
try {
|
CollectionAdminRequest.createCollectionWithImplicitRouter("fine", "fine", "invalid$shard@name",1,0,0);
|
||||||
createRequest.setShards("invalid$shard@name");
|
});
|
||||||
fail();
|
final String exceptionMessage = e.getMessage();
|
||||||
} catch (SolrException e) {
|
assertTrue(exceptionMessage.contains("Invalid shard"));
|
||||||
final String exceptionMessage = e.getMessage();
|
assertTrue(exceptionMessage.contains("invalid$shard@name"));
|
||||||
assertTrue(exceptionMessage.contains("Invalid shard"));
|
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
||||||
assertTrue(exceptionMessage.contains("invalid$shard@name"));
|
}
|
||||||
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
|
||||||
}
|
@Test
|
||||||
|
public void testInvalidShardNamesRejectedWhenCallingSetShards() {
|
||||||
|
CollectionAdminRequest.Create request = CollectionAdminRequest.createCollectionWithImplicitRouter("fine",null,"fine",1);
|
||||||
|
final SolrException e = expectThrows(SolrException.class, () -> {
|
||||||
|
request.setShards("invalid$shard@name");
|
||||||
|
});
|
||||||
|
final String exceptionMessage = e.getMessage();
|
||||||
|
assertTrue(exceptionMessage.contains("Invalid shard"));
|
||||||
|
assertTrue(exceptionMessage.contains("invalid$shard@name"));
|
||||||
|
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInvalidAliasNameRejectedWhenCreatingAlias() {
|
public void testInvalidAliasNameRejectedWhenCreatingAlias() {
|
||||||
final CreateAlias createAliasRequest = new CreateAlias();
|
final SolrException e = expectThrows(SolrException.class, () -> {
|
||||||
try {
|
CreateAlias createAliasRequest = CollectionAdminRequest.createAlias("invalid$alias@name","ignored");
|
||||||
createAliasRequest.setAliasName("invalid$alias@name");
|
});
|
||||||
fail();
|
final String exceptionMessage = e.getMessage();
|
||||||
} catch (SolrException e) {
|
assertTrue(exceptionMessage.contains("Invalid alias"));
|
||||||
final String exceptionMessage = e.getMessage();
|
assertTrue(exceptionMessage.contains("invalid$alias@name"));
|
||||||
assertTrue(exceptionMessage.contains("Invalid alias"));
|
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
||||||
assertTrue(exceptionMessage.contains("invalid$alias@name"));
|
|
||||||
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testInvalidShardNameRejectedWhenCreatingShard() {
|
public void testInvalidShardNameRejectedWhenCreatingShard() {
|
||||||
final CreateShard createShardRequest = new CreateShard();
|
final SolrException e = expectThrows(SolrException.class, () -> {
|
||||||
try {
|
CreateShard createShardRequest = CollectionAdminRequest.createShard("ignored","invalid$shard@name");
|
||||||
createShardRequest.setShardName("invalid$shard@name");
|
});
|
||||||
fail();
|
final String exceptionMessage = e.getMessage();
|
||||||
} catch (SolrException e) {
|
assertTrue(exceptionMessage.contains("Invalid shard"));
|
||||||
final String exceptionMessage = e.getMessage();
|
assertTrue(exceptionMessage.contains("invalid$shard@name"));
|
||||||
assertTrue(exceptionMessage.contains("Invalid shard"));
|
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
||||||
assertTrue(exceptionMessage.contains("invalid$shard@name"));
|
|
||||||
assertTrue(exceptionMessage.contains("must consist entirely of periods, underscores, hyphens, and alphanumerics"));
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1892,8 +1892,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
|
||||||
throws SolrServerException, IOException {
|
throws SolrServerException, IOException {
|
||||||
CollectionAdminResponse resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
CollectionAdminResponse resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
||||||
if (resp.getResponse().get("failure") != null) {
|
if (resp.getResponse().get("failure") != null) {
|
||||||
CollectionAdminRequest.Delete req = new CollectionAdminRequest.Delete();
|
CollectionAdminRequest.Delete req = CollectionAdminRequest.deleteCollection(testCollectionName);
|
||||||
req.setCollectionName(testCollectionName);
|
|
||||||
req.process(cloudClient);
|
req.process(cloudClient);
|
||||||
|
|
||||||
resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
resp = createCollection(testCollectionName, numShards, replicationFactor, maxShardsPerNode);
|
||||||
|
@ -2158,6 +2157,22 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Logs a WARN if collection can't be deleted, but does not fail or throw an exception
|
||||||
|
* @return true if success, else false
|
||||||
|
*/
|
||||||
|
protected static boolean attemptCollectionDelete(CloudSolrClient client, String collectionName) {
|
||||||
|
// try to clean up
|
||||||
|
try {
|
||||||
|
CollectionAdminRequest.deleteCollection(collectionName).process(client);
|
||||||
|
return true;
|
||||||
|
} catch (Exception e) {
|
||||||
|
// don't fail the test
|
||||||
|
log.warn("Could not delete collection {} - ignoring", collectionName);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
protected void logReplicationDetails(Replica replica, StringBuilder builder) throws IOException {
|
protected void logReplicationDetails(Replica replica, StringBuilder builder) throws IOException {
|
||||||
try (HttpSolrClient client = new HttpSolrClient.Builder(replica.getCoreUrl()).build()) {
|
try (HttpSolrClient client = new HttpSolrClient.Builder(replica.getCoreUrl()).build()) {
|
||||||
ModifiableSolrParams params = new ModifiableSolrParams();
|
ModifiableSolrParams params = new ModifiableSolrParams();
|
||||||
|
@ -2203,9 +2218,7 @@ public abstract class AbstractFullDistribZkTestBase extends AbstractDistribZkTes
|
||||||
}
|
}
|
||||||
|
|
||||||
static CollectionAdminResponse getStatusResponse(String requestId, SolrClient client) throws SolrServerException, IOException {
|
static CollectionAdminResponse getStatusResponse(String requestId, SolrClient client) throws SolrServerException, IOException {
|
||||||
CollectionAdminRequest.RequestStatus requestStatusRequest = new CollectionAdminRequest.RequestStatus();
|
return CollectionAdminRequest.requestStatus(requestId).process(client);
|
||||||
requestStatusRequest.setRequestId(requestId);
|
|
||||||
return requestStatusRequest.process(client);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue