mirror of https://github.com/apache/lucene.git
stats tests: avoid grabbing core, use short form for creating requests, generify tests to take other fields
git-svn-id: https://svn.apache.org/repos/asf/lucene/solr/trunk@822001 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
f090dd8fbc
commit
8fc279937d
|
@ -49,22 +49,28 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
lrf = h.getRequestFactory("standard", 0, 20);
|
lrf = h.getRequestFactory("standard", 0, 20);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testFieldStatisticsResult() throws Exception {
|
public void testStats() throws Exception {
|
||||||
SolrCore core = h.getCore();
|
for (String f : new String[] {"stats_i"}) {
|
||||||
assertU(adoc("id", "1", "stats_i", "-10"));
|
doTestFieldStatisticsResult(f);
|
||||||
assertU(adoc("id", "2", "stats_i", "-20"));
|
doTestFieldStatisticsMissingResult(f);
|
||||||
assertU(adoc("id", "3", "stats_i", "-30"));
|
doTestFacetStatisticsResult(f);
|
||||||
assertU(adoc("id", "4", "stats_i", "-40"));
|
doTestFacetStatisticsMissingResult(f);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (String f : new String[] {"stats_ii"}) {
|
||||||
|
doTestMVFieldStatisticsResult(f);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public void doTestFieldStatisticsResult(String f) throws Exception {
|
||||||
|
assertU(adoc("id", "1", f, "-10"));
|
||||||
|
assertU(adoc("id", "2", f, "-20"));
|
||||||
|
assertU(adoc("id", "3", f, "-30"));
|
||||||
|
assertU(adoc("id", "4", f, "-40"));
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
|
|
||||||
Map<String, String> args = new HashMap<String, String>();
|
assertQ("test statistics values", req("q","*:*", "stats","true", "stats.field",f)
|
||||||
args.put(CommonParams.Q, "*:*");
|
|
||||||
args.put(StatsParams.STATS, "true");
|
|
||||||
args.put(StatsParams.STATS_FIELD, "stats_i");
|
|
||||||
args.put("indent", "true");
|
|
||||||
SolrQueryRequest req = new LocalSolrQueryRequest(core, new MapSolrParams(args));
|
|
||||||
|
|
||||||
assertQ("test statistics values", req
|
|
||||||
, "//double[@name='min'][.='-40.0']"
|
, "//double[@name='min'][.='-40.0']"
|
||||||
, "//double[@name='max'][.='-10.0']"
|
, "//double[@name='max'][.='-10.0']"
|
||||||
, "//double[@name='sum'][.='-100.0']"
|
, "//double[@name='sum'][.='-100.0']"
|
||||||
|
@ -77,36 +83,16 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void testMVFieldStatisticsResult() throws Exception {
|
public void doTestMVFieldStatisticsResult(String f) throws Exception {
|
||||||
SolrCore core = h.getCore();
|
assertU(adoc("id", "1", f, "-10", f, "-100", "active_s", "true"));
|
||||||
|
assertU(adoc("id", "2", f, "-20", f, "200", "active_s", "true"));
|
||||||
|
|
||||||
assertU(adoc("id", "1", "stats_ii", "-10", "stats_ii", "-100", "active_s", "true"));
|
assertU(adoc("id", "3", f, "-30", f, "-1", "active_s", "false"));
|
||||||
assertU(adoc("id", "2", "stats_ii", "-20", "stats_ii", "200", "active_s", "true"));
|
assertU(adoc("id", "4", f, "-40", f, "10", "active_s", "false"));
|
||||||
|
|
||||||
assertU(adoc("id", "3", "stats_ii", "-30", "stats_ii", "-1", "active_s", "false"));
|
|
||||||
assertU(adoc("id", "4", "stats_ii", "-40", "stats_ii", "10", "active_s", "false"));
|
|
||||||
assertU(adoc("id", "5", "active_s", "false"));
|
assertU(adoc("id", "5", "active_s", "false"));
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
Map<String, String> args = new HashMap<String, String>();
|
|
||||||
args.put(CommonParams.Q, "*:*");
|
|
||||||
args.put(StatsParams.STATS, "true");
|
|
||||||
args.put(StatsParams.STATS_FIELD, "stats_ii");
|
|
||||||
args.put("indent", "true");
|
|
||||||
SolrQueryRequest req = new LocalSolrQueryRequest(core, new MapSolrParams(args));
|
|
||||||
assertQ("test statistics values", req
|
|
||||||
, "//double[@name='min'][.='-100.0']"
|
|
||||||
, "//double[@name='max'][.='200.0']"
|
|
||||||
, "//double[@name='sum'][.='9.0']"
|
|
||||||
, "//long[@name='count'][.='8']"
|
|
||||||
, "//long[@name='missing'][.='1']"
|
|
||||||
, "//double[@name='sumOfSquares'][.='53101.0']"
|
|
||||||
, "//double[@name='mean'][.='1.125']"
|
|
||||||
, "//double[@name='stddev'][.='87.08852228787508']"
|
|
||||||
);
|
|
||||||
args.put(StatsParams.STATS_FACET, "active_s");
|
|
||||||
req = new LocalSolrQueryRequest(core, new MapSolrParams(args));
|
|
||||||
|
|
||||||
assertQ("test statistics values", req
|
assertQ("test statistics values", req("q","*:*", "stats","true", "stats.field",f)
|
||||||
, "//double[@name='min'][.='-100.0']"
|
, "//double[@name='min'][.='-100.0']"
|
||||||
, "//double[@name='max'][.='200.0']"
|
, "//double[@name='max'][.='200.0']"
|
||||||
, "//double[@name='sum'][.='9.0']"
|
, "//double[@name='sum'][.='9.0']"
|
||||||
|
@ -116,7 +102,19 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
, "//double[@name='mean'][.='1.125']"
|
, "//double[@name='mean'][.='1.125']"
|
||||||
, "//double[@name='stddev'][.='87.08852228787508']"
|
, "//double[@name='stddev'][.='87.08852228787508']"
|
||||||
);
|
);
|
||||||
assertQ("test value for active_s=true", req
|
|
||||||
|
assertQ("test statistics values", req("q","*:*", "stats","true", "stats.field",f, "stats.facet","active_s")
|
||||||
|
, "//double[@name='min'][.='-100.0']"
|
||||||
|
, "//double[@name='max'][.='200.0']"
|
||||||
|
, "//double[@name='sum'][.='9.0']"
|
||||||
|
, "//long[@name='count'][.='8']"
|
||||||
|
, "//long[@name='missing'][.='1']"
|
||||||
|
, "//double[@name='sumOfSquares'][.='53101.0']"
|
||||||
|
, "//double[@name='mean'][.='1.125']"
|
||||||
|
, "//double[@name='stddev'][.='87.08852228787508']"
|
||||||
|
);
|
||||||
|
|
||||||
|
assertQ("test value for active_s=true", req("q","*:*", "stats","true", "stats.field",f, "stats.facet","active_s")
|
||||||
, "//lst[@name='true']/double[@name='min'][.='-100.0']"
|
, "//lst[@name='true']/double[@name='min'][.='-100.0']"
|
||||||
, "//lst[@name='true']/double[@name='max'][.='200.0']"
|
, "//lst[@name='true']/double[@name='max'][.='200.0']"
|
||||||
, "//lst[@name='true']/double[@name='sum'][.='70.0']"
|
, "//lst[@name='true']/double[@name='sum'][.='70.0']"
|
||||||
|
@ -142,22 +140,14 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void testFieldStatisticsMissingResult() throws Exception {
|
public void doTestFieldStatisticsMissingResult(String f) throws Exception {
|
||||||
SolrCore core = h.getCore();
|
assertU(adoc("id", "1", f, "-10"));
|
||||||
assertU(adoc("id", "1", "stats_i", "-10"));
|
assertU(adoc("id", "2", f, "-20"));
|
||||||
assertU(adoc("id", "2", "stats_i", "-20"));
|
|
||||||
assertU(adoc("id", "3"));
|
assertU(adoc("id", "3"));
|
||||||
assertU(adoc("id", "4", "stats_i", "-40"));
|
assertU(adoc("id", "4", f, "-40"));
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
|
|
||||||
Map<String, String> args = new HashMap<String, String>();
|
assertQ("test statistics values", req("q","*:*", "stats","true", "stats.field",f)
|
||||||
args.put(CommonParams.Q, "*:*");
|
|
||||||
args.put(StatsParams.STATS, "true");
|
|
||||||
args.put(StatsParams.STATS_FIELD, "stats_i");
|
|
||||||
args.put("indent", "true");
|
|
||||||
SolrQueryRequest req = new LocalSolrQueryRequest(core, new MapSolrParams(args));
|
|
||||||
|
|
||||||
assertQ("test statistics values", req
|
|
||||||
, "//double[@name='min'][.='-40.0']"
|
, "//double[@name='min'][.='-40.0']"
|
||||||
, "//double[@name='max'][.='-10.0']"
|
, "//double[@name='max'][.='-10.0']"
|
||||||
, "//double[@name='sum'][.='-70.0']"
|
, "//double[@name='sum'][.='-70.0']"
|
||||||
|
@ -169,23 +159,14 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testFacetStatisticsResult() throws Exception {
|
public void doTestFacetStatisticsResult(String f) throws Exception {
|
||||||
SolrCore core = h.getCore();
|
assertU(adoc("id", "1", f, "10", "active_s", "true"));
|
||||||
assertU(adoc("id", "1", "stats_i", "10", "active_s", "true"));
|
assertU(adoc("id", "2", f, "20", "active_s", "true"));
|
||||||
assertU(adoc("id", "2", "stats_i", "20", "active_s", "true"));
|
assertU(adoc("id", "3", f, "30", "active_s", "false"));
|
||||||
assertU(adoc("id", "3", "stats_i", "30", "active_s", "false"));
|
assertU(adoc("id", "4", f, "40", "active_s", "false"));
|
||||||
assertU(adoc("id", "4", "stats_i", "40", "active_s", "false"));
|
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
|
|
||||||
Map<String, String> args = new HashMap<String, String>();
|
assertQ("test value for active_s=true", req("q","*:*", "stats","true", "stats.field",f, "stats.facet","active_s")
|
||||||
args.put(CommonParams.Q, "*:*");
|
|
||||||
args.put(StatsParams.STATS, "true");
|
|
||||||
args.put(StatsParams.STATS_FIELD, "stats_i");
|
|
||||||
args.put(StatsParams.STATS_FACET, "active_s");
|
|
||||||
args.put("indent", "true");
|
|
||||||
SolrQueryRequest req = new LocalSolrQueryRequest(core, new MapSolrParams(args));
|
|
||||||
|
|
||||||
assertQ("test value for active_s=true", req
|
|
||||||
, "//lst[@name='true']/double[@name='min'][.='10.0']"
|
, "//lst[@name='true']/double[@name='min'][.='10.0']"
|
||||||
, "//lst[@name='true']/double[@name='max'][.='20.0']"
|
, "//lst[@name='true']/double[@name='max'][.='20.0']"
|
||||||
, "//lst[@name='true']/double[@name='sum'][.='30.0']"
|
, "//lst[@name='true']/double[@name='sum'][.='30.0']"
|
||||||
|
@ -196,7 +177,7 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
, "//lst[@name='true']/double[@name='stddev'][.='7.0710678118654755']"
|
, "//lst[@name='true']/double[@name='stddev'][.='7.0710678118654755']"
|
||||||
);
|
);
|
||||||
|
|
||||||
assertQ("test value for active_s=false", req
|
assertQ("test value for active_s=false", req("q","*:*", "stats","true", "stats.field",f, "stats.facet","active_s")
|
||||||
, "//lst[@name='false']/double[@name='min'][.='30.0']"
|
, "//lst[@name='false']/double[@name='min'][.='30.0']"
|
||||||
, "//lst[@name='false']/double[@name='max'][.='40.0']"
|
, "//lst[@name='false']/double[@name='max'][.='40.0']"
|
||||||
, "//lst[@name='false']/double[@name='sum'][.='70.0']"
|
, "//lst[@name='false']/double[@name='sum'][.='70.0']"
|
||||||
|
@ -208,23 +189,14 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testFacetStatisticsMissingResult() throws Exception {
|
public void doTestFacetStatisticsMissingResult(String f) throws Exception {
|
||||||
SolrCore core = h.getCore();
|
assertU(adoc("id", "1", f, "10", "active_s", "true"));
|
||||||
assertU(adoc("id", "1", "stats_i", "10", "active_s", "true"));
|
assertU(adoc("id", "2", f, "20", "active_s", "true"));
|
||||||
assertU(adoc("id", "2", "stats_i", "20", "active_s", "true"));
|
|
||||||
assertU(adoc("id", "3", "active_s", "false"));
|
assertU(adoc("id", "3", "active_s", "false"));
|
||||||
assertU(adoc("id", "4", "stats_i", "40", "active_s", "false"));
|
assertU(adoc("id", "4", f, "40", "active_s", "false"));
|
||||||
assertU(commit());
|
assertU(commit());
|
||||||
|
|
||||||
Map<String, String> args = new HashMap<String, String>();
|
assertQ("test value for active_s=true", req("q","*:*", "stats","true", "stats.field",f, "stats.facet","active_s")
|
||||||
args.put(CommonParams.Q, "*:*");
|
|
||||||
args.put(StatsParams.STATS, "true");
|
|
||||||
args.put(StatsParams.STATS_FIELD, "stats_i");
|
|
||||||
args.put(StatsParams.STATS_FACET, "active_s");
|
|
||||||
args.put("indent", "true");
|
|
||||||
SolrQueryRequest req = new LocalSolrQueryRequest(core, new MapSolrParams(args));
|
|
||||||
|
|
||||||
assertQ("test value for active_s=true", req
|
|
||||||
, "//lst[@name='true']/double[@name='min'][.='10.0']"
|
, "//lst[@name='true']/double[@name='min'][.='10.0']"
|
||||||
, "//lst[@name='true']/double[@name='max'][.='20.0']"
|
, "//lst[@name='true']/double[@name='max'][.='20.0']"
|
||||||
, "//lst[@name='true']/double[@name='sum'][.='30.0']"
|
, "//lst[@name='true']/double[@name='sum'][.='30.0']"
|
||||||
|
@ -235,7 +207,7 @@ public class StatsComponentTest extends AbstractSolrTestCase {
|
||||||
, "//lst[@name='true']/double[@name='stddev'][.='7.0710678118654755']"
|
, "//lst[@name='true']/double[@name='stddev'][.='7.0710678118654755']"
|
||||||
);
|
);
|
||||||
|
|
||||||
assertQ("test value for active_s=false", req
|
assertQ("test value for active_s=false", req("q","*:*", "stats","true", "stats.field",f, "stats.facet","active_s")
|
||||||
, "//lst[@name='false']/double[@name='min'][.='40.0']"
|
, "//lst[@name='false']/double[@name='min'][.='40.0']"
|
||||||
, "//lst[@name='false']/double[@name='max'][.='40.0']"
|
, "//lst[@name='false']/double[@name='max'][.='40.0']"
|
||||||
, "//lst[@name='false']/double[@name='sum'][.='40.0']"
|
, "//lst[@name='false']/double[@name='sum'][.='40.0']"
|
||||||
|
|
Loading…
Reference in New Issue