Tests for derivative reducer
Most tests have been marked with @AwaitsFix since they require functionality to be implemented before they will pass
This commit is contained in:
parent
511e275825
commit
f68bce51f1
|
@ -116,7 +116,8 @@ public class DerivativeReducer extends Reducer {
|
||||||
}
|
}
|
||||||
lastBucketValue = thisBucketValue;
|
lastBucketValue = thisBucketValue;
|
||||||
}
|
}
|
||||||
return factory.create(histo.getName(), newBuckets, null, 1, null, null, false, new ArrayList<Reducer>(), histo.getMetaData()); // NOCOMMIT get order, minDocCount, emptyBucketInfo etc. from histo
|
return factory.create(histo.getName(), newBuckets, histo.getOrder(), 1, null, null, false, new ArrayList<Reducer>(),
|
||||||
|
histo.getMetaData()); // NOCOMMIT get order, minDocCount, emptyBucketInfo etc. from histo
|
||||||
}
|
}
|
||||||
|
|
||||||
private Double resolveBucketValue(InternalHistogram<? extends InternalHistogram.Bucket> histo, InternalHistogram.Bucket bucket) {
|
private Double resolveBucketValue(InternalHistogram<? extends InternalHistogram.Bucket> histo, InternalHistogram.Bucket bucket) {
|
||||||
|
|
|
@ -0,0 +1,321 @@
|
||||||
|
/*
|
||||||
|
* Licensed to Elasticsearch under one or more contributor
|
||||||
|
* license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright
|
||||||
|
* ownership. Elasticsearch licenses this file to you under
|
||||||
|
* the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.elasticsearch.search.aggregations.reducers;
|
||||||
|
|
||||||
|
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
||||||
|
import org.elasticsearch.action.index.IndexRequestBuilder;
|
||||||
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
|
import org.elasticsearch.index.mapper.core.DateFieldMapper;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.DateHistogramInterval;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.Histogram;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.Histogram.Bucket;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.InternalHistogram;
|
||||||
|
import org.elasticsearch.search.aggregations.metrics.sum.Sum;
|
||||||
|
import org.elasticsearch.search.aggregations.support.AggregationPath;
|
||||||
|
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
|
import org.joda.time.DateTime;
|
||||||
|
import org.joda.time.DateTimeZone;
|
||||||
|
import org.joda.time.format.DateTimeFormat;
|
||||||
|
import org.junit.After;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
import static org.elasticsearch.search.aggregations.AggregationBuilders.dateHistogram;
|
||||||
|
import static org.elasticsearch.search.aggregations.AggregationBuilders.sum;
|
||||||
|
import static org.elasticsearch.search.aggregations.reducers.ReducerBuilders.derivative;
|
||||||
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertSearchResponse;
|
||||||
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.core.IsNull.notNullValue;
|
||||||
|
import static org.hamcrest.core.IsNull.nullValue;
|
||||||
|
|
||||||
|
@ElasticsearchIntegrationTest.SuiteScopeTest
|
||||||
|
//@AwaitsFix(bugUrl = "Fix factory selection for serialisation of Internal derivative")
|
||||||
|
public class DateDerivativeTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
private DateTime date(int month, int day) {
|
||||||
|
return new DateTime(2012, month, day, 0, 0, DateTimeZone.UTC);
|
||||||
|
}
|
||||||
|
|
||||||
|
private DateTime date(String date) {
|
||||||
|
return DateFieldMapper.Defaults.DATE_TIME_FORMATTER.parser().parseDateTime(date);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static String format(DateTime date, String pattern) {
|
||||||
|
return DateTimeFormat.forPattern(pattern).print(date);
|
||||||
|
}
|
||||||
|
|
||||||
|
private IndexRequestBuilder indexDoc(String idx, DateTime date, int value) throws Exception {
|
||||||
|
return client().prepareIndex(idx, "type").setSource(
|
||||||
|
jsonBuilder().startObject().field("date", date).field("value", value).startArray("dates").value(date)
|
||||||
|
.value(date.plusMonths(1).plusDays(1)).endArray().endObject());
|
||||||
|
}
|
||||||
|
|
||||||
|
private IndexRequestBuilder indexDoc(int month, int day, int value) throws Exception {
|
||||||
|
return client().prepareIndex("idx", "type").setSource(
|
||||||
|
jsonBuilder().startObject().field("value", value).field("date", date(month, day)).startArray("dates")
|
||||||
|
.value(date(month, day)).value(date(month + 1, day + 1)).endArray().endObject());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setupSuiteScopeCluster() throws Exception {
|
||||||
|
createIndex("idx");
|
||||||
|
createIndex("idx_unmapped");
|
||||||
|
// TODO: would be nice to have more random data here
|
||||||
|
prepareCreate("empty_bucket_idx").addMapping("type", "value", "type=integer").execute().actionGet();
|
||||||
|
List<IndexRequestBuilder> builders = new ArrayList<>();
|
||||||
|
for (int i = 0; i < 2; i++) {
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + i).setSource(
|
||||||
|
jsonBuilder().startObject().field("value", i * 2).endObject()));
|
||||||
|
}
|
||||||
|
builders.addAll(Arrays.asList(indexDoc(1, 2, 1), // date: Jan 2, dates: Jan 2, Feb 3
|
||||||
|
indexDoc(2, 2, 2), // date: Feb 2, dates: Feb 2, Mar 3
|
||||||
|
indexDoc(2, 15, 3), // date: Feb 15, dates: Feb 15, Mar 16
|
||||||
|
indexDoc(3, 2, 4), // date: Mar 2, dates: Mar 2, Apr 3
|
||||||
|
indexDoc(3, 15, 5), // date: Mar 15, dates: Mar 15, Apr 16
|
||||||
|
indexDoc(3, 23, 6))); // date: Mar 23, dates: Mar 23, Apr 24
|
||||||
|
indexRandom(true, builders);
|
||||||
|
ensureSearchable();
|
||||||
|
}
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void afterEachTest() throws IOException {
|
||||||
|
internalCluster().wipeIndices("idx2");
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl = "waiting for derivative to support _count")
|
||||||
|
// NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void singleValuedField() throws Exception {
|
||||||
|
SearchResponse response = client()
|
||||||
|
.prepareSearch("idx")
|
||||||
|
.addAggregation(
|
||||||
|
dateHistogram("histo").field("date").interval(DateHistogramInterval.MONTH)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count"))).execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(2));
|
||||||
|
|
||||||
|
DateTime key = new DateTime(2012, 1, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1d));
|
||||||
|
|
||||||
|
key = new DateTime(2012, 2, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1d));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void singleValuedField_WithSubAggregation() throws Exception {
|
||||||
|
SearchResponse response = client()
|
||||||
|
.prepareSearch("idx")
|
||||||
|
.addAggregation(
|
||||||
|
dateHistogram("histo").field("date").interval(DateHistogramInterval.MONTH)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("sum")).subAggregation(sum("sum").field("value")))
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram histo = response.getAggregations().get("histo");
|
||||||
|
assertThat(histo, notNullValue());
|
||||||
|
assertThat(histo.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = histo.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(3));
|
||||||
|
Object[] propertiesKeys = (Object[]) histo.getProperty("_key");
|
||||||
|
Object[] propertiesDocCounts = (Object[]) histo.getProperty("_count");
|
||||||
|
Object[] propertiesCounts = (Object[]) histo.getProperty("sum.value");
|
||||||
|
|
||||||
|
DateTime key = new DateTime(2012, 1, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(1l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
Sum sum = bucket.getAggregations().get("sum");
|
||||||
|
assertThat(sum, notNullValue());
|
||||||
|
assertThat(sum.getValue(), equalTo(1.0));
|
||||||
|
SimpleValue deriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(deriv, nullValue());
|
||||||
|
assertThat((DateTime) propertiesKeys[0], equalTo(key));
|
||||||
|
assertThat((long) propertiesDocCounts[0], equalTo(1l));
|
||||||
|
assertThat((double) propertiesCounts[0], equalTo(1.0));
|
||||||
|
|
||||||
|
key = new DateTime(2012, 2, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(2l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
sum = bucket.getAggregations().get("sum");
|
||||||
|
assertThat(sum, notNullValue());
|
||||||
|
assertThat(sum.getValue(), equalTo(5.0));
|
||||||
|
deriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.value(), equalTo(4.0));
|
||||||
|
assertThat((double) bucket.getProperty("histo", AggregationPath.parse("deriv.value").getPathElementsAsStringList()), equalTo(4.0));
|
||||||
|
assertThat((DateTime) propertiesKeys[1], equalTo(key));
|
||||||
|
assertThat((long) propertiesDocCounts[1], equalTo(2l));
|
||||||
|
assertThat((double) propertiesCounts[1], equalTo(5.0));
|
||||||
|
|
||||||
|
key = new DateTime(2012, 3, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
bucket = buckets.get(2);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(3l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
sum = bucket.getAggregations().get("sum");
|
||||||
|
assertThat(sum, notNullValue());
|
||||||
|
assertThat(sum.getValue(), equalTo(15.0));
|
||||||
|
deriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.value(), equalTo(10.0));
|
||||||
|
assertThat((double) bucket.getProperty("histo", AggregationPath.parse("deriv.value").getPathElementsAsStringList()), equalTo(10.0));
|
||||||
|
assertThat((DateTime) propertiesKeys[2], equalTo(key));
|
||||||
|
assertThat((long) propertiesDocCounts[2], equalTo(3l));
|
||||||
|
assertThat((double) propertiesCounts[2], equalTo(15.0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl = "waiting for derivative to support _count")
|
||||||
|
// NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void multiValuedField() throws Exception {
|
||||||
|
SearchResponse response = client()
|
||||||
|
.prepareSearch("idx")
|
||||||
|
.addAggregation(
|
||||||
|
dateHistogram("histo").field("dates").interval(DateHistogramInterval.MONTH)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count"))).execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(3));
|
||||||
|
|
||||||
|
DateTime key = new DateTime(2012, 1, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(2.0));
|
||||||
|
|
||||||
|
key = new DateTime(2012, 2, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(2.0));
|
||||||
|
|
||||||
|
key = new DateTime(2012, 3, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
bucket = buckets.get(2);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-2.0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl = "waiting for derivative to support _count")
|
||||||
|
// NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void unmapped() throws Exception {
|
||||||
|
SearchResponse response = client()
|
||||||
|
.prepareSearch("idx_unmapped")
|
||||||
|
.addAggregation(
|
||||||
|
dateHistogram("histo").field("date").interval(DateHistogramInterval.MONTH)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count"))).execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
assertThat(deriv.getBuckets().size(), equalTo(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl = "waiting for derivative to support _count")
|
||||||
|
// NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void partiallyUnmapped() throws Exception {
|
||||||
|
SearchResponse response = client()
|
||||||
|
.prepareSearch("idx", "idx_unmapped")
|
||||||
|
.addAggregation(
|
||||||
|
dateHistogram("histo").field("date").interval(DateHistogramInterval.MONTH)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count"))).execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(2));
|
||||||
|
|
||||||
|
DateTime key = new DateTime(2012, 1, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1.0));
|
||||||
|
|
||||||
|
key = new DateTime(2012, 2, 1, 0, 0, DateTimeZone.UTC);
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat((DateTime) bucket.getKey(), equalTo(key));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1.0));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,568 @@
|
||||||
|
/*
|
||||||
|
* Licensed to Elasticsearch under one or more contributor
|
||||||
|
* license agreements. See the NOTICE file distributed with
|
||||||
|
* this work for additional information regarding copyright
|
||||||
|
* ownership. Elasticsearch licenses this file to you under
|
||||||
|
* the Apache License, Version 2.0 (the "License"); you may
|
||||||
|
* not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.elasticsearch.search.aggregations.reducers;
|
||||||
|
|
||||||
|
import org.apache.lucene.util.LuceneTestCase.AwaitsFix;
|
||||||
|
import org.elasticsearch.action.index.IndexRequestBuilder;
|
||||||
|
import org.elasticsearch.action.search.SearchResponse;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.Histogram;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.Histogram.Bucket;
|
||||||
|
import org.elasticsearch.search.aggregations.bucket.histogram.InternalHistogram;
|
||||||
|
import org.elasticsearch.search.aggregations.metrics.sum.Sum;
|
||||||
|
import org.elasticsearch.search.aggregations.support.AggregationPath;
|
||||||
|
import org.elasticsearch.test.ElasticsearchIntegrationTest;
|
||||||
|
import org.hamcrest.Matchers;
|
||||||
|
import org.junit.Test;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder;
|
||||||
|
import static org.elasticsearch.index.query.QueryBuilders.matchAllQuery;
|
||||||
|
import static org.elasticsearch.search.aggregations.AggregationBuilders.histogram;
|
||||||
|
import static org.elasticsearch.search.aggregations.AggregationBuilders.sum;
|
||||||
|
import static org.elasticsearch.search.aggregations.reducers.ReducerBuilders.derivative;
|
||||||
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
||||||
|
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertSearchResponse;
|
||||||
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
import static org.hamcrest.Matchers.is;
|
||||||
|
import static org.hamcrest.core.IsNull.notNullValue;
|
||||||
|
|
||||||
|
@ElasticsearchIntegrationTest.SuiteScopeTest
|
||||||
|
public class DerivativeTests extends ElasticsearchIntegrationTest {
|
||||||
|
|
||||||
|
private static final String SINGLE_VALUED_FIELD_NAME = "l_value";
|
||||||
|
private static final String MULTI_VALUED_FIELD_NAME = "l_values";
|
||||||
|
|
||||||
|
static int numDocs;
|
||||||
|
static int interval;
|
||||||
|
static int numValueBuckets, numValuesBuckets;
|
||||||
|
static int numFirstDerivValueBuckets, numFirstDerivValuesBuckets;
|
||||||
|
static long[] valueCounts, valuesCounts;
|
||||||
|
static long[] firstDerivValueCounts, firstDerivValuesCounts;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setupSuiteScopeCluster() throws Exception {
|
||||||
|
createIndex("idx");
|
||||||
|
createIndex("idx_unmapped");
|
||||||
|
|
||||||
|
numDocs = randomIntBetween(6, 20);
|
||||||
|
interval = randomIntBetween(2, 5);
|
||||||
|
|
||||||
|
numValueBuckets = numDocs / interval + 1;
|
||||||
|
valueCounts = new long[numValueBuckets];
|
||||||
|
for (int i = 0; i < numDocs; i++) {
|
||||||
|
final int bucket = (i + 1) / interval;
|
||||||
|
valueCounts[bucket]++;
|
||||||
|
}
|
||||||
|
|
||||||
|
numValuesBuckets = (numDocs + 1) / interval + 1;
|
||||||
|
valuesCounts = new long[numValuesBuckets];
|
||||||
|
for (int i = 0; i < numDocs; i++) {
|
||||||
|
final int bucket1 = (i + 1) / interval;
|
||||||
|
final int bucket2 = (i + 2) / interval;
|
||||||
|
valuesCounts[bucket1]++;
|
||||||
|
if (bucket1 != bucket2) {
|
||||||
|
valuesCounts[bucket2]++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
numFirstDerivValueBuckets = numValueBuckets - 1;
|
||||||
|
firstDerivValueCounts = new long[numFirstDerivValueBuckets];
|
||||||
|
long lastValueCount = -1;
|
||||||
|
for (int i = 0; i < numValueBuckets; i++) {
|
||||||
|
long thisValue = valueCounts[i];
|
||||||
|
if (lastValueCount != -1) {
|
||||||
|
long diff = thisValue - lastValueCount;
|
||||||
|
firstDerivValueCounts[i - 1] = diff;
|
||||||
|
}
|
||||||
|
lastValueCount = thisValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
numFirstDerivValuesBuckets = numValuesBuckets - 1;
|
||||||
|
firstDerivValuesCounts = new long[numFirstDerivValuesBuckets];
|
||||||
|
long lastValuesCount = -1;
|
||||||
|
for (int i = 0; i < numValuesBuckets; i++) {
|
||||||
|
long thisValue = valuesCounts[i];
|
||||||
|
if (lastValuesCount != -1) {
|
||||||
|
long diff = thisValue - lastValuesCount;
|
||||||
|
firstDerivValuesCounts[i - 1] = diff;
|
||||||
|
}
|
||||||
|
lastValuesCount = thisValue;
|
||||||
|
}
|
||||||
|
|
||||||
|
List<IndexRequestBuilder> builders = new ArrayList<>();
|
||||||
|
|
||||||
|
for (int i = 0; i < numDocs; i++) {
|
||||||
|
builders.add(client().prepareIndex("idx", "type").setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, i + 1).startArray(MULTI_VALUED_FIELD_NAME).value(i + 1)
|
||||||
|
.value(i + 2).endArray().field("tag", "tag" + i).endObject()));
|
||||||
|
}
|
||||||
|
|
||||||
|
assertAcked(prepareCreate("empty_bucket_idx").addMapping("type", SINGLE_VALUED_FIELD_NAME, "type=integer"));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 0).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 0).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 1).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 1).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 2).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 2).endObject()));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 3).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 2).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 4).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 4).endObject()));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 5).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 4).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 6).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 5).endObject()));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 7).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 5).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 8).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 9).endObject()));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 9).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 9).endObject()));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 10).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 9).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 11).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 10).endObject()));
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 12).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 10).endObject()));
|
||||||
|
|
||||||
|
builders.add(client().prepareIndex("empty_bucket_idx", "type", "" + 13).setSource(
|
||||||
|
jsonBuilder().startObject().field(SINGLE_VALUED_FIELD_NAME, 11).endObject()));
|
||||||
|
|
||||||
|
indexRandom(true, builders);
|
||||||
|
ensureSearchable();
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void singleValuedField() {
|
||||||
|
|
||||||
|
SearchResponse response = client().prepareSearch("idx")
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count")))
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(numFirstDerivValueBuckets));
|
||||||
|
|
||||||
|
for (int i = 0; i < numFirstDerivValueBuckets; ++i) {
|
||||||
|
Histogram.Bucket bucket = buckets.get(i);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(bucket.getKeyAsString(), equalTo(String.valueOf(i * interval)));
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo((long) i * interval));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(valueCounts[i]));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo((double) firstDerivValueCounts[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void singleValuedField_WithSubAggregation() throws Exception {
|
||||||
|
SearchResponse response = client()
|
||||||
|
.prepareSearch("idx")
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(sum("sum").field(SINGLE_VALUED_FIELD_NAME))
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("sum"))).execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
assertThat(deriv.getBuckets().size(), equalTo(numValueBuckets));
|
||||||
|
Object[] propertiesKeys = (Object[]) deriv.getProperty("_key");
|
||||||
|
Object[] propertiesDocCounts = (Object[]) deriv.getProperty("_count");
|
||||||
|
Object[] propertiesSumCounts = (Object[]) deriv.getProperty("sum.value");
|
||||||
|
|
||||||
|
List<Histogram.Bucket> buckets = new ArrayList<>(deriv.getBuckets());
|
||||||
|
for (int i = 0; i < numValueBuckets; ++i) {
|
||||||
|
Histogram.Bucket bucket = buckets.get(i);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(bucket.getKeyAsString(), equalTo(String.valueOf(i * interval)));
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo((long) i * interval));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(valueCounts[i]));
|
||||||
|
assertThat(bucket.getAggregations().asList().isEmpty(), is(false));
|
||||||
|
Sum sum = bucket.getAggregations().get("sum");
|
||||||
|
assertThat(sum, notNullValue());
|
||||||
|
long s = 0;
|
||||||
|
for (int j = 0; j < numDocs; ++j) {
|
||||||
|
if ((j + 1) / interval == i) {
|
||||||
|
s += j + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
assertThat(sum.getValue(), equalTo((double) s));
|
||||||
|
if (i > 0) {
|
||||||
|
SimpleValue sumDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(sumDeriv, notNullValue());
|
||||||
|
long s1 = 0;
|
||||||
|
long s2 = 0;
|
||||||
|
for (int j = 0; j < numDocs; ++j) {
|
||||||
|
if ((j + 1) / interval == i - 1) {
|
||||||
|
s1 += j + 1;
|
||||||
|
}
|
||||||
|
if ((j + 1) / interval == i) {
|
||||||
|
s2 += j + 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
long sumDerivValue = s2 - s1;
|
||||||
|
assertThat(sumDeriv.value(), equalTo((double) sumDerivValue));
|
||||||
|
assertThat((double) bucket.getProperty("histo", AggregationPath.parse("deriv.value").getPathElementsAsStringList()),
|
||||||
|
equalTo((double) sumDerivValue));
|
||||||
|
}
|
||||||
|
assertThat((long) propertiesKeys[i], equalTo((long) i * interval));
|
||||||
|
assertThat((long) propertiesDocCounts[i], equalTo(valueCounts[i]));
|
||||||
|
assertThat((double) propertiesSumCounts[i], equalTo((double) s));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void multiValuedField() throws Exception {
|
||||||
|
SearchResponse response = client().prepareSearch("idx")
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(MULTI_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count")))
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = deriv.getBuckets();
|
||||||
|
assertThat(deriv.getBuckets().size(), equalTo(numFirstDerivValuesBuckets));
|
||||||
|
|
||||||
|
for (int i = 0; i < numFirstDerivValuesBuckets; ++i) {
|
||||||
|
Histogram.Bucket bucket = buckets.get(i);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(bucket.getKeyAsString(), equalTo(String.valueOf(i * interval)));
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo((long) i * interval));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(valueCounts[i]));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo((double) firstDerivValuesCounts[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void unmapped() throws Exception {
|
||||||
|
SearchResponse response = client().prepareSearch("idx_unmapped")
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count")))
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
assertThat(deriv.getBuckets().size(), equalTo(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void partiallyUnmapped() throws Exception {
|
||||||
|
SearchResponse response = client().prepareSearch("idx", "idx_unmapped")
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count")))
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertSearchResponse(response);
|
||||||
|
|
||||||
|
InternalHistogram deriv = response.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<? extends Bucket> buckets = deriv.getBuckets();
|
||||||
|
assertThat(deriv.getBuckets().size(), equalTo(numFirstDerivValueBuckets));
|
||||||
|
|
||||||
|
for (int i = 0; i < numFirstDerivValueBuckets; ++i) {
|
||||||
|
Histogram.Bucket bucket = buckets.get(i);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(bucket.getKeyAsString(), equalTo(String.valueOf(i * interval)));
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo((long) i * interval));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(valueCounts[i]));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo((double) firstDerivValueCounts[i]));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count and gaps") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void singleValuedFieldWithGaps() throws Exception {
|
||||||
|
SearchResponse searchResponse = client()
|
||||||
|
.prepareSearch("empty_bucket_idx")
|
||||||
|
.setQuery(matchAllQuery())
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count")))
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertThat(searchResponse.getHits().getTotalHits(), equalTo(14l));
|
||||||
|
|
||||||
|
InternalHistogram deriv = searchResponse.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, Matchers.notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<Histogram.Bucket> buckets = (List<Bucket>) deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(5));
|
||||||
|
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(0l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(1l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1d));
|
||||||
|
|
||||||
|
bucket = buckets.get(2);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(4l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(3);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(9l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-1d));
|
||||||
|
|
||||||
|
bucket = buckets.get(4);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(10l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-1d));
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count and insert_zeros gap policy") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void singleValuedFieldWithGaps_insertZeros() throws Exception {
|
||||||
|
SearchResponse searchResponse = client()
|
||||||
|
.prepareSearch("empty_bucket_idx")
|
||||||
|
.setQuery(matchAllQuery())
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count"))) // NOCOMMIT add insert_zeros gapPolicy
|
||||||
|
.execute().actionGet();
|
||||||
|
|
||||||
|
assertThat(searchResponse.getHits().getTotalHits(), equalTo(14l));
|
||||||
|
|
||||||
|
InternalHistogram deriv = searchResponse.getAggregations().get("histo");
|
||||||
|
assertThat(deriv, Matchers.notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<Histogram.Bucket> buckets = (List<Bucket>) deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(11));
|
||||||
|
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(0l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(1l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1d));
|
||||||
|
|
||||||
|
bucket = buckets.get(2);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(2l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-2d));
|
||||||
|
|
||||||
|
bucket = buckets.get(3);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(3l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(2d));
|
||||||
|
|
||||||
|
bucket = buckets.get(4);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(4l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(5);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(5l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-2d));
|
||||||
|
|
||||||
|
bucket = buckets.get(6);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(6l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(7);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(7l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(8);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(8l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(3d));
|
||||||
|
|
||||||
|
bucket = buckets.get(9);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(9l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-1d));
|
||||||
|
|
||||||
|
bucket = buckets.get(10);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(10l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-1d));
|
||||||
|
}
|
||||||
|
|
||||||
|
@AwaitsFix(bugUrl="waiting for derivative to support _count and interpolate gapPolicy") // NOCOMMIT
|
||||||
|
@Test
|
||||||
|
public void singleValuedFieldWithGaps_interpolate() throws Exception {
|
||||||
|
SearchResponse searchResponse = client()
|
||||||
|
.prepareSearch("empty_bucket_idx")
|
||||||
|
.setQuery(matchAllQuery())
|
||||||
|
.addAggregation(
|
||||||
|
histogram("histo").field(SINGLE_VALUED_FIELD_NAME).interval(interval)
|
||||||
|
.subAggregation(derivative("deriv").setBucketsPaths("_count"))).execute().actionGet(); // NOCOMMIT add interpolate gapPolicy
|
||||||
|
|
||||||
|
assertThat(searchResponse.getHits().getTotalHits(), equalTo(14l));
|
||||||
|
|
||||||
|
InternalHistogram deriv = searchResponse.getAggregations().get("deriv");
|
||||||
|
assertThat(deriv, Matchers.notNullValue());
|
||||||
|
assertThat(deriv.getName(), equalTo("histo"));
|
||||||
|
List<Histogram.Bucket> buckets = (List<Bucket>) deriv.getBuckets();
|
||||||
|
assertThat(buckets.size(), equalTo(7));
|
||||||
|
|
||||||
|
Histogram.Bucket bucket = buckets.get(0);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(0l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
SimpleValue docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(1);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(1l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(1d));
|
||||||
|
|
||||||
|
bucket = buckets.get(2);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(2l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(3);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(4l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0d));
|
||||||
|
|
||||||
|
bucket = buckets.get(4);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(5l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(0.25d));
|
||||||
|
|
||||||
|
bucket = buckets.get(5);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(9l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-1d));
|
||||||
|
|
||||||
|
bucket = buckets.get(6);
|
||||||
|
assertThat(bucket, notNullValue());
|
||||||
|
assertThat(((Number) bucket.getKey()).longValue(), equalTo(10l));
|
||||||
|
assertThat(bucket.getDocCount(), equalTo(0l));
|
||||||
|
docCountDeriv = bucket.getAggregations().get("deriv");
|
||||||
|
assertThat(docCountDeriv, notNullValue());
|
||||||
|
assertThat(docCountDeriv.value(), equalTo(-1d));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue