SOLR-10190: Fix NPE in CloudSolrClient when reading stale alias

This closes #160
This commit is contained in:
Tomas Fernandez Lobbe 2017-02-24 17:33:12 -08:00
parent 30125f99da
commit 39887b8629
3 changed files with 30 additions and 0 deletions

View File

@ -275,6 +275,8 @@ Bug Fixes
* SOLR-10083: Fix instanceof check in ConstDoubleSource.equals (Pushkar Raste via Christine Poerschke) * SOLR-10083: Fix instanceof check in ConstDoubleSource.equals (Pushkar Raste via Christine Poerschke)
* SOLR-10190: Fix NPE in CloudSolrClient when reading stale alias (Janosch Woschitz via Tomás Fernández Löbbe)
================== 6.4.1 ================== ================== 6.4.1 ==================
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.

View File

@ -1075,6 +1075,9 @@ public class CloudSolrClient extends SolrClient {
for (String requestedCollection : requestedCollectionNames) { for (String requestedCollection : requestedCollectionNames) {
// track the version of state we're using on the client side using the _stateVer_ param // track the version of state we're using on the client side using the _stateVer_ param
DocCollection coll = getDocCollection(requestedCollection, null); DocCollection coll = getDocCollection(requestedCollection, null);
if (coll == null) {
throw new SolrException(ErrorCode.BAD_REQUEST, "Collection not found: " + requestedCollection);
}
int collVer = coll.getZNodeVersion(); int collVer = coll.getZNodeVersion();
if (coll.getStateFormat()>1) { if (coll.getStateFormat()>1) {
if(requestedCollections == null) requestedCollections = new ArrayList<>(requestedCollectionNames.size()); if(requestedCollections == null) requestedCollections = new ArrayList<>(requestedCollectionNames.size());

View File

@ -146,6 +146,31 @@ public class CloudSolrClientTest extends SolrCloudTestCase {
} }
@Test
public void testHandlingOfStaleAlias() throws Exception {
try (CloudSolrClient client = getCloudSolrClient(cluster.getZkServer().getZkAddress())) {
client.setDefaultCollection("misconfigured-alias");
CollectionAdminRequest.createCollection("nemesis", "conf", 2, 1).process(client);
CollectionAdminRequest.createAlias("misconfigured-alias", "nemesis").process(client);
CollectionAdminRequest.deleteCollection("nemesis").process(client);
List<SolrInputDocument> docs = new ArrayList<>();
SolrInputDocument doc = new SolrInputDocument();
doc.addField(id, Integer.toString(1));
docs.add(doc);
try {
client.add(docs);
fail("Alias points to non-existing collection, add should fail");
} catch (SolrException e) {
assertEquals(SolrException.ErrorCode.BAD_REQUEST.code, e.code());
assertTrue("Unexpected error exception", e.getMessage().contains("Collection not found"));
}
}
}
@Test @Test
public void testRouting() throws Exception { public void testRouting() throws Exception {