mirror of https://github.com/apache/lucene.git
SOLR-10254: significantTerms Streaming Expression should work in non-SolrCloud mode
This commit is contained in:
parent
8756be0540
commit
682c6a7d51
|
@ -18,6 +18,7 @@ package org.apache.solr.handler;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.lang.invoke.MethodHandles;
|
import java.lang.invoke.MethodHandles;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
|
@ -246,6 +247,7 @@ public class StreamHandler extends RequestHandlerBase implements SolrCoreAware,
|
||||||
int worker = params.getInt("workerID", 0);
|
int worker = params.getInt("workerID", 0);
|
||||||
int numWorkers = params.getInt("numWorkers", 1);
|
int numWorkers = params.getInt("numWorkers", 1);
|
||||||
StreamContext context = new StreamContext();
|
StreamContext context = new StreamContext();
|
||||||
|
context.put("shards", getCollectionShards(params));
|
||||||
context.workerID = worker;
|
context.workerID = worker;
|
||||||
context.numWorkers = numWorkers;
|
context.numWorkers = numWorkers;
|
||||||
context.setSolrClientCache(clientCache);
|
context.setSolrClientCache(clientCache);
|
||||||
|
@ -509,4 +511,29 @@ public class StreamHandler extends RequestHandlerBase implements SolrCoreAware,
|
||||||
return tuple;
|
return tuple;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Map<String, List<String>> getCollectionShards(SolrParams params) {
|
||||||
|
|
||||||
|
Map<String, List<String>> collectionShards = new HashMap();
|
||||||
|
Iterator<String> paramsIt = params.getParameterNamesIterator();
|
||||||
|
while(paramsIt.hasNext()) {
|
||||||
|
String param = paramsIt.next();
|
||||||
|
if(param.indexOf(".shards") > -1) {
|
||||||
|
String collection = param.split("\\.")[0];
|
||||||
|
String shardString = params.get(param);
|
||||||
|
String[] shards = shardString.split(",");
|
||||||
|
List<String> shardList = new ArrayList();
|
||||||
|
for(String shard : shards) {
|
||||||
|
shardList.add(shard);
|
||||||
|
}
|
||||||
|
collectionShards.put(collection, shardList);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(collectionShards.size() > 0) {
|
||||||
|
return collectionShards;
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -74,12 +74,9 @@ public class SignificantTermsStream extends TupleStream implements Expressible{
|
||||||
|
|
||||||
protected transient SolrClientCache cache;
|
protected transient SolrClientCache cache;
|
||||||
protected transient boolean isCloseCache;
|
protected transient boolean isCloseCache;
|
||||||
protected transient CloudSolrClient cloudSolrClient;
|
|
||||||
|
|
||||||
protected transient StreamContext streamContext;
|
protected transient StreamContext streamContext;
|
||||||
protected ExecutorService executorService;
|
protected ExecutorService executorService;
|
||||||
|
|
||||||
|
|
||||||
public SignificantTermsStream(String zkHost,
|
public SignificantTermsStream(String zkHost,
|
||||||
String collectionName,
|
String collectionName,
|
||||||
Map params,
|
Map params,
|
||||||
|
@ -168,12 +165,12 @@ public class SignificantTermsStream extends TupleStream implements Expressible{
|
||||||
String zkHost = null;
|
String zkHost = null;
|
||||||
if(null == zkHostExpression){
|
if(null == zkHostExpression){
|
||||||
zkHost = factory.getCollectionZkHost(collectionName);
|
zkHost = factory.getCollectionZkHost(collectionName);
|
||||||
}
|
} else if(zkHostExpression.getParameter() instanceof StreamExpressionValue) {
|
||||||
else if(zkHostExpression.getParameter() instanceof StreamExpressionValue){
|
|
||||||
zkHost = ((StreamExpressionValue)zkHostExpression.getParameter()).getValue();
|
zkHost = ((StreamExpressionValue)zkHostExpression.getParameter()).getValue();
|
||||||
}
|
}
|
||||||
if(null == zkHost){
|
|
||||||
throw new IOException(String.format(Locale.ROOT,"invalid expression %s - zkHost not found for collection '%s'",expression,collectionName));
|
if(zkHost == null){
|
||||||
|
zkHost = factory.getDefaultZkHost();
|
||||||
}
|
}
|
||||||
|
|
||||||
// We've got all the required items
|
// We've got all the required items
|
||||||
|
@ -238,47 +235,13 @@ public class SignificantTermsStream extends TupleStream implements Expressible{
|
||||||
isCloseCache = false;
|
isCloseCache = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.cloudSolrClient = this.cache.getCloudSolrClient(zkHost);
|
this.executorService = ExecutorUtil.newMDCAwareCachedThreadPool(new SolrjNamedThreadFactory("SignificantTermsStream"));
|
||||||
this.executorService = ExecutorUtil.newMDCAwareCachedThreadPool(new SolrjNamedThreadFactory("FeaturesSelectionStream"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<TupleStream> children() {
|
public List<TupleStream> children() {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<String> getShardUrls() throws IOException {
|
|
||||||
try {
|
|
||||||
ZkStateReader zkStateReader = cloudSolrClient.getZkStateReader();
|
|
||||||
|
|
||||||
Collection<Slice> slices = CloudSolrStream.getSlices(this.collection, zkStateReader, false);
|
|
||||||
|
|
||||||
ClusterState clusterState = zkStateReader.getClusterState();
|
|
||||||
Set<String> liveNodes = clusterState.getLiveNodes();
|
|
||||||
|
|
||||||
List<String> baseUrls = new ArrayList<>();
|
|
||||||
for(Slice slice : slices) {
|
|
||||||
Collection<Replica> replicas = slice.getReplicas();
|
|
||||||
List<Replica> shuffler = new ArrayList<>();
|
|
||||||
for(Replica replica : replicas) {
|
|
||||||
if(replica.getState() == Replica.State.ACTIVE && liveNodes.contains(replica.getNodeName())) {
|
|
||||||
shuffler.add(replica);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Collections.shuffle(shuffler, new Random());
|
|
||||||
Replica rep = shuffler.get(0);
|
|
||||||
ZkCoreNodeProps zkProps = new ZkCoreNodeProps(rep);
|
|
||||||
String url = zkProps.getCoreUrl();
|
|
||||||
baseUrls.add(url);
|
|
||||||
}
|
|
||||||
|
|
||||||
return baseUrls;
|
|
||||||
|
|
||||||
} catch (Exception e) {
|
|
||||||
throw new IOException(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private List<Future<NamedList>> callShards(List<String> baseUrls) throws IOException {
|
private List<Future<NamedList>> callShards(List<String> baseUrls) throws IOException {
|
||||||
|
|
||||||
List<Future<NamedList>> futures = new ArrayList<>();
|
List<Future<NamedList>> futures = new ArrayList<>();
|
||||||
|
@ -326,7 +289,7 @@ public class SignificantTermsStream extends TupleStream implements Expressible{
|
||||||
Map<String, int[]> mergeFreqs = new HashMap<>();
|
Map<String, int[]> mergeFreqs = new HashMap<>();
|
||||||
long numDocs = 0;
|
long numDocs = 0;
|
||||||
long resultCount = 0;
|
long resultCount = 0;
|
||||||
for (Future<NamedList> getTopTermsCall : callShards(getShardUrls())) {
|
for (Future<NamedList> getTopTermsCall : callShards(getShards(zkHost, collection, streamContext))) {
|
||||||
NamedList resp = getTopTermsCall.get();
|
NamedList resp = getTopTermsCall.get();
|
||||||
|
|
||||||
List<String> terms = (List<String>)resp.get("sterms");
|
List<String> terms = (List<String>)resp.get("sterms");
|
||||||
|
|
|
@ -19,9 +19,16 @@ package org.apache.solr.client.solrj.io.stream;
|
||||||
import java.io.Closeable;
|
import java.io.Closeable;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
import java.util.Random;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.UUID;
|
import java.util.UUID;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.apache.solr.client.solrj.impl.CloudSolrClient;
|
||||||
import org.apache.solr.client.solrj.io.Tuple;
|
import org.apache.solr.client.solrj.io.Tuple;
|
||||||
import org.apache.solr.client.solrj.io.comp.StreamComparator;
|
import org.apache.solr.client.solrj.io.comp.StreamComparator;
|
||||||
import org.apache.solr.client.solrj.io.stream.expr.Explanation;
|
import org.apache.solr.client.solrj.io.stream.expr.Explanation;
|
||||||
|
@ -29,6 +36,14 @@ import org.apache.solr.client.solrj.io.stream.expr.StreamFactory;
|
||||||
import org.apache.solr.common.IteratorWriter;
|
import org.apache.solr.common.IteratorWriter;
|
||||||
import org.apache.solr.common.MapWriter;
|
import org.apache.solr.common.MapWriter;
|
||||||
import org.apache.solr.common.SolrException;
|
import org.apache.solr.common.SolrException;
|
||||||
|
import org.apache.solr.common.cloud.Aliases;
|
||||||
|
import org.apache.solr.common.cloud.ClusterState;
|
||||||
|
import org.apache.solr.common.cloud.DocCollection;
|
||||||
|
import org.apache.solr.common.cloud.Replica;
|
||||||
|
import org.apache.solr.common.cloud.Slice;
|
||||||
|
import org.apache.solr.common.cloud.ZkCoreNodeProps;
|
||||||
|
import org.apache.solr.common.cloud.ZkStateReader;
|
||||||
|
import org.apache.solr.common.util.StrUtils;
|
||||||
|
|
||||||
|
|
||||||
public abstract class TupleStream implements Closeable, Serializable, MapWriter {
|
public abstract class TupleStream implements Closeable, Serializable, MapWriter {
|
||||||
|
@ -84,4 +99,83 @@ public abstract class TupleStream implements Closeable, Serializable, MapWriter
|
||||||
public UUID getStreamNodeId(){
|
public UUID getStreamNodeId(){
|
||||||
return streamNodeId;
|
return streamNodeId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public static List<String> getShards(String zkHost,
|
||||||
|
String collection,
|
||||||
|
StreamContext streamContext)
|
||||||
|
throws IOException {
|
||||||
|
Map<String, List<String>> shardsMap = null;
|
||||||
|
List<String> shards = new ArrayList();
|
||||||
|
|
||||||
|
if(streamContext != null) {
|
||||||
|
shardsMap = (Map<String, List<String>>)streamContext.get("shards");
|
||||||
|
}
|
||||||
|
|
||||||
|
if(shardsMap != null) {
|
||||||
|
//Manual Sharding
|
||||||
|
shards = shardsMap.get(collection);
|
||||||
|
} else {
|
||||||
|
//SolrCloud Sharding
|
||||||
|
CloudSolrClient cloudSolrClient = streamContext.getSolrClientCache().getCloudSolrClient(zkHost);
|
||||||
|
ZkStateReader zkStateReader = cloudSolrClient.getZkStateReader();
|
||||||
|
ClusterState clusterState = zkStateReader.getClusterState();
|
||||||
|
Collection<Slice> slices = getSlices(collection, zkStateReader, true);
|
||||||
|
Set<String> liveNodes = clusterState.getLiveNodes();
|
||||||
|
for(Slice slice : slices) {
|
||||||
|
Collection<Replica> replicas = slice.getReplicas();
|
||||||
|
List<Replica> shuffler = new ArrayList<>();
|
||||||
|
for(Replica replica : replicas) {
|
||||||
|
if(replica.getState() == Replica.State.ACTIVE && liveNodes.contains(replica.getNodeName()))
|
||||||
|
shuffler.add(replica);
|
||||||
|
}
|
||||||
|
|
||||||
|
Collections.shuffle(shuffler, new Random());
|
||||||
|
Replica rep = shuffler.get(0);
|
||||||
|
ZkCoreNodeProps zkProps = new ZkCoreNodeProps(rep);
|
||||||
|
String url = zkProps.getCoreUrl();
|
||||||
|
shards.add(url);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return shards;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static Collection<Slice> getSlices(String collectionName,
|
||||||
|
ZkStateReader zkStateReader,
|
||||||
|
boolean checkAlias) throws IOException {
|
||||||
|
ClusterState clusterState = zkStateReader.getClusterState();
|
||||||
|
|
||||||
|
Map<String, DocCollection> collectionsMap = clusterState.getCollectionsMap();
|
||||||
|
|
||||||
|
// Check collection case sensitive
|
||||||
|
if(collectionsMap.containsKey(collectionName)) {
|
||||||
|
return collectionsMap.get(collectionName).getActiveSlices();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check collection case insensitive
|
||||||
|
for(String collectionMapKey : collectionsMap.keySet()) {
|
||||||
|
if(collectionMapKey.equalsIgnoreCase(collectionName)) {
|
||||||
|
return collectionsMap.get(collectionMapKey).getActiveSlices();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(checkAlias) {
|
||||||
|
// check for collection alias
|
||||||
|
Aliases aliases = zkStateReader.getAliases();
|
||||||
|
String alias = aliases.getCollectionAlias(collectionName);
|
||||||
|
if (alias != null) {
|
||||||
|
Collection<Slice> slices = new ArrayList<>();
|
||||||
|
|
||||||
|
List<String> aliasList = StrUtils.splitSmart(alias, ",", true);
|
||||||
|
for (String aliasCollectionName : aliasList) {
|
||||||
|
// Add all active slices for this alias collection
|
||||||
|
slices.addAll(collectionsMap.get(aliasCollectionName).getActiveSlices());
|
||||||
|
}
|
||||||
|
|
||||||
|
return slices;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
throw new IOException("Slices not found for " + collectionName);
|
||||||
|
}
|
||||||
}
|
}
|
|
@ -4712,8 +4712,6 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
@Test
|
@Test
|
||||||
public void testSignificantTermsStream() throws Exception {
|
public void testSignificantTermsStream() throws Exception {
|
||||||
|
|
||||||
Assume.assumeTrue(!useAlias);
|
|
||||||
|
|
||||||
UpdateRequest updateRequest = new UpdateRequest();
|
UpdateRequest updateRequest = new UpdateRequest();
|
||||||
for (int i = 0; i < 5000; i++) {
|
for (int i = 0; i < 5000; i++) {
|
||||||
updateRequest.add(id, "a"+i, "test_t", "a b c d m l");
|
updateRequest.add(id, "a"+i, "test_t", "a b c d m l");
|
||||||
|
@ -4742,10 +4740,17 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
StreamFactory factory = new StreamFactory()
|
StreamFactory factory = new StreamFactory()
|
||||||
.withCollectionZkHost("collection1", cluster.getZkServer().getZkAddress())
|
.withCollectionZkHost("collection1", cluster.getZkServer().getZkAddress())
|
||||||
|
.withDefaultZkHost(cluster.getZkServer().getZkAddress())
|
||||||
.withFunctionName("significantTerms", SignificantTermsStream.class);
|
.withFunctionName("significantTerms", SignificantTermsStream.class);
|
||||||
|
|
||||||
|
StreamContext streamContext = new StreamContext();
|
||||||
|
SolrClientCache cache = new SolrClientCache();
|
||||||
|
streamContext.setSolrClientCache(cache);
|
||||||
|
try {
|
||||||
|
|
||||||
String significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, minTermLength=1, maxDocFreq=\".5\")";
|
String significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, minTermLength=1, maxDocFreq=\".5\")";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
|
|
||||||
assert (tuples.size() == 3);
|
assert (tuples.size() == 3);
|
||||||
|
@ -4765,6 +4770,7 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
//Test maxDocFreq
|
//Test maxDocFreq
|
||||||
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, maxDocFreq=2650, minTermLength=1)";
|
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, maxDocFreq=2650, minTermLength=1)";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
|
|
||||||
assert (tuples.size() == 1);
|
assert (tuples.size() == 1);
|
||||||
|
@ -4776,6 +4782,7 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, maxDocFreq=\".45\", minTermLength=1)";
|
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, maxDocFreq=\".45\", minTermLength=1)";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
assert (tuples.size() == 1);
|
assert (tuples.size() == 1);
|
||||||
assertTrue(tuples.get(0).get("term").equals("l"));
|
assertTrue(tuples.get(0).get("term").equals("l"));
|
||||||
|
@ -4786,6 +4793,7 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
//Test min doc freq
|
//Test min doc freq
|
||||||
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, minDocFreq=\"2700\", minTermLength=1, maxDocFreq=\".5\")";
|
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, minDocFreq=\"2700\", minTermLength=1, maxDocFreq=\".5\")";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
|
|
||||||
assert (tuples.size() == 3);
|
assert (tuples.size() == 3);
|
||||||
|
@ -4806,6 +4814,7 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
//Test min doc freq percent
|
//Test min doc freq percent
|
||||||
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, minDocFreq=\".478\", minTermLength=1, maxDocFreq=\".5\")";
|
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=3, minDocFreq=\".478\", minTermLength=1, maxDocFreq=\".5\")";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
|
|
||||||
assert (tuples.size() == 1);
|
assert (tuples.size() == 1);
|
||||||
|
@ -4814,11 +4823,11 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
assertTrue(tuples.get(0).getLong("background") == 5900);
|
assertTrue(tuples.get(0).getLong("background") == 5900);
|
||||||
assertTrue(tuples.get(0).getLong("foreground") == 5000);
|
assertTrue(tuples.get(0).getLong("foreground") == 5000);
|
||||||
|
|
||||||
|
|
||||||
//Test limit
|
//Test limit
|
||||||
|
|
||||||
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=2, minDocFreq=\"2700\", minTermLength=1, maxDocFreq=\".5\")";
|
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=2, minDocFreq=\"2700\", minTermLength=1, maxDocFreq=\".5\")";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
|
|
||||||
assert (tuples.size() == 2);
|
assert (tuples.size() == 2);
|
||||||
|
@ -4835,13 +4844,82 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
|
|
||||||
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=2, minDocFreq=\"2700\", minTermLength=2)";
|
significantTerms = "significantTerms(collection1, q=\"id:a*\", field=\"test_t\", limit=2, minDocFreq=\"2700\", minTermLength=2)";
|
||||||
stream = factory.constructStream(significantTerms);
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(streamContext);
|
||||||
tuples = getTuples(stream);
|
tuples = getTuples(stream);
|
||||||
assert (tuples.size() == 0);
|
assert (tuples.size() == 0);
|
||||||
|
|
||||||
|
|
||||||
|
//Test with shards parameter
|
||||||
|
List<String> shardUrls = TupleStream.getShards(cluster.getZkServer().getZkAddress(), COLLECTIONORALIAS, streamContext);
|
||||||
|
|
||||||
|
Map<String, List<String>> shardsMap = new HashMap();
|
||||||
|
shardsMap.put("myCollection", shardUrls);
|
||||||
|
StreamContext context = new StreamContext();
|
||||||
|
context.put("shards", shardsMap);
|
||||||
|
context.setSolrClientCache(cache);
|
||||||
|
significantTerms = "significantTerms(myCollection, q=\"id:a*\", field=\"test_t\", limit=2, minDocFreq=\"2700\", minTermLength=1, maxDocFreq=\".5\")";
|
||||||
|
stream = factory.constructStream(significantTerms);
|
||||||
|
stream.setStreamContext(context);
|
||||||
|
tuples = getTuples(stream);
|
||||||
|
|
||||||
|
assert (tuples.size() == 2);
|
||||||
|
|
||||||
|
assertTrue(tuples.get(0).get("term").equals("m"));
|
||||||
|
assertTrue(tuples.get(0).getLong("background") == 5500);
|
||||||
|
assertTrue(tuples.get(0).getLong("foreground") == 5000);
|
||||||
|
|
||||||
|
assertTrue(tuples.get(1).get("term").equals("d"));
|
||||||
|
assertTrue(tuples.get(1).getLong("background") == 5600);
|
||||||
|
assertTrue(tuples.get(1).getLong("foreground") == 5000);
|
||||||
|
|
||||||
|
//Execersise the /stream hander
|
||||||
|
|
||||||
|
//Add the shards http parameter for the myCollection
|
||||||
|
StringBuilder buf = new StringBuilder();
|
||||||
|
for (String shardUrl : shardUrls) {
|
||||||
|
if (buf.length() > 0) {
|
||||||
|
buf.append(",");
|
||||||
|
}
|
||||||
|
buf.append(shardUrl);
|
||||||
|
}
|
||||||
|
|
||||||
|
ModifiableSolrParams solrParams = new ModifiableSolrParams();
|
||||||
|
solrParams.add("qt", "/stream");
|
||||||
|
solrParams.add("expr", significantTerms);
|
||||||
|
solrParams.add("myCollection.shards", buf.toString());
|
||||||
|
SolrStream solrStream = new SolrStream(shardUrls.get(0), solrParams);
|
||||||
|
tuples = getTuples(solrStream);
|
||||||
|
assert (tuples.size() == 2);
|
||||||
|
|
||||||
|
assertTrue(tuples.get(0).get("term").equals("m"));
|
||||||
|
assertTrue(tuples.get(0).getLong("background") == 5500);
|
||||||
|
assertTrue(tuples.get(0).getLong("foreground") == 5000);
|
||||||
|
|
||||||
|
assertTrue(tuples.get(1).get("term").equals("d"));
|
||||||
|
assertTrue(tuples.get(1).getLong("background") == 5600);
|
||||||
|
assertTrue(tuples.get(1).getLong("foreground") == 5000);
|
||||||
|
|
||||||
|
//Add a negative test to prove that it cannot find slices if shards parameter is removed
|
||||||
|
|
||||||
|
try {
|
||||||
|
ModifiableSolrParams solrParamsBad = new ModifiableSolrParams();
|
||||||
|
solrParamsBad.add("qt", "/stream");
|
||||||
|
solrParamsBad.add("expr", significantTerms);
|
||||||
|
solrStream = new SolrStream(shardUrls.get(0), solrParamsBad);
|
||||||
|
tuples = getTuples(solrStream);
|
||||||
|
throw new Exception("Exception should have been thrown above");
|
||||||
|
} catch (IOException e) {
|
||||||
|
assertTrue(e.getMessage().contains("Slices not found for myCollection"));
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
cache.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testComplementStream() throws Exception {
|
public void testComplementStream() throws Exception {
|
||||||
|
|
||||||
|
@ -4920,12 +4998,16 @@ public class StreamExpressionTest extends SolrCloudTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
protected List<Tuple> getTuples(TupleStream tupleStream) throws IOException {
|
protected List<Tuple> getTuples(TupleStream tupleStream) throws IOException {
|
||||||
tupleStream.open();
|
|
||||||
List<Tuple> tuples = new ArrayList<Tuple>();
|
List<Tuple> tuples = new ArrayList<Tuple>();
|
||||||
|
|
||||||
|
try {
|
||||||
|
tupleStream.open();
|
||||||
for (Tuple t = tupleStream.read(); !t.EOF; t = tupleStream.read()) {
|
for (Tuple t = tupleStream.read(); !t.EOF; t = tupleStream.read()) {
|
||||||
tuples.add(t);
|
tuples.add(t);
|
||||||
}
|
}
|
||||||
|
} finally {
|
||||||
tupleStream.close();
|
tupleStream.close();
|
||||||
|
}
|
||||||
return tuples;
|
return tuples;
|
||||||
}
|
}
|
||||||
protected boolean assertOrder(List<Tuple> tuples, int... ids) throws Exception {
|
protected boolean assertOrder(List<Tuple> tuples, int... ids) throws Exception {
|
||||||
|
|
Loading…
Reference in New Issue