mirror of https://github.com/apache/druid.git
topn with granularity regression fixes (#17565)
* topn with granularity regression fixes changes: * fix issue where topN with query granularity other than ALL would use the heap algorithm when it was actual able to use the pooled algorithm, and incorrectly used the pool algorithm in cases where it must use the heap algorithm, a regression from #16533 * fix issue where topN with query granularity other than ALL could incorrectly process values in the wrong time bucket, another regression from #16533 * move defensive check outside of loop * more test * extra layer of safety * move check outside of loop * fix spelling * add query context parameter to allow using pooled algorithm for topN when multi-passes is required even wihen query granularity is not all * add comment, revert IT context changes and add new context flag
This commit is contained in:
parent
98b960c6ac
commit
de9da37384
|
@ -94,7 +94,8 @@
|
||||||
"context": {
|
"context": {
|
||||||
"useCache": "true",
|
"useCache": "true",
|
||||||
"populateCache": "true",
|
"populateCache": "true",
|
||||||
"timeout": 60000
|
"timeout": 60000,
|
||||||
|
"useTopNMultiPassPooledQueryGranularity": "true"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"expectedResults": [
|
"expectedResults": [
|
||||||
|
@ -198,7 +199,8 @@
|
||||||
"context": {
|
"context": {
|
||||||
"useCache": "true",
|
"useCache": "true",
|
||||||
"populateCache": "true",
|
"populateCache": "true",
|
||||||
"timeout": 60000
|
"timeout": 60000,
|
||||||
|
"useTopNMultiPassPooledQueryGranularity": "true"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"expectedResults": [
|
"expectedResults": [
|
||||||
|
@ -322,7 +324,8 @@
|
||||||
"context": {
|
"context": {
|
||||||
"useCache": "true",
|
"useCache": "true",
|
||||||
"populateCache": "true",
|
"populateCache": "true",
|
||||||
"timeout": 60000
|
"timeout": 60000,
|
||||||
|
"useTopNMultiPassPooledQueryGranularity": "true"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"expectedResults": [
|
"expectedResults": [
|
||||||
|
@ -741,7 +744,8 @@
|
||||||
"context": {
|
"context": {
|
||||||
"useCache": "true",
|
"useCache": "true",
|
||||||
"populateCache": "true",
|
"populateCache": "true",
|
||||||
"timeout": 60000
|
"timeout": 60000,
|
||||||
|
"useTopNMultiPassPooledQueryGranularity": "true"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"expectedResults": [
|
"expectedResults": [
|
||||||
|
|
|
@ -24,6 +24,7 @@ import com.google.common.collect.Iterables;
|
||||||
import com.google.common.collect.Lists;
|
import com.google.common.collect.Lists;
|
||||||
import org.apache.druid.error.DruidException;
|
import org.apache.druid.error.DruidException;
|
||||||
import org.apache.druid.java.util.common.DateTimes;
|
import org.apache.druid.java.util.common.DateTimes;
|
||||||
|
import org.apache.druid.java.util.common.Intervals;
|
||||||
import org.apache.druid.java.util.common.granularity.Granularities;
|
import org.apache.druid.java.util.common.granularity.Granularities;
|
||||||
import org.apache.druid.java.util.common.granularity.Granularity;
|
import org.apache.druid.java.util.common.granularity.Granularity;
|
||||||
import org.apache.druid.segment.ColumnValueSelector;
|
import org.apache.druid.segment.ColumnValueSelector;
|
||||||
|
@ -94,11 +95,13 @@ public class CursorGranularizer
|
||||||
timeSelector = cursor.getColumnSelectorFactory().makeColumnValueSelector(ColumnHolder.TIME_COLUMN_NAME);
|
timeSelector = cursor.getColumnSelectorFactory().makeColumnValueSelector(ColumnHolder.TIME_COLUMN_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
return new CursorGranularizer(cursor, bucketIterable, timeSelector, timeOrder == Order.DESCENDING);
|
return new CursorGranularizer(cursor, granularity, bucketIterable, timeSelector, timeOrder == Order.DESCENDING);
|
||||||
}
|
}
|
||||||
|
|
||||||
private final Cursor cursor;
|
private final Cursor cursor;
|
||||||
|
|
||||||
|
private final Granularity granularity;
|
||||||
|
|
||||||
// Iterable that iterates over time buckets.
|
// Iterable that iterates over time buckets.
|
||||||
private final Iterable<Interval> bucketIterable;
|
private final Iterable<Interval> bucketIterable;
|
||||||
|
|
||||||
|
@ -112,12 +115,14 @@ public class CursorGranularizer
|
||||||
|
|
||||||
private CursorGranularizer(
|
private CursorGranularizer(
|
||||||
Cursor cursor,
|
Cursor cursor,
|
||||||
|
Granularity granularity,
|
||||||
Iterable<Interval> bucketIterable,
|
Iterable<Interval> bucketIterable,
|
||||||
@Nullable ColumnValueSelector timeSelector,
|
@Nullable ColumnValueSelector timeSelector,
|
||||||
boolean descending
|
boolean descending
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
this.cursor = cursor;
|
this.cursor = cursor;
|
||||||
|
this.granularity = granularity;
|
||||||
this.bucketIterable = bucketIterable;
|
this.bucketIterable = bucketIterable;
|
||||||
this.timeSelector = timeSelector;
|
this.timeSelector = timeSelector;
|
||||||
this.descending = descending;
|
this.descending = descending;
|
||||||
|
@ -133,13 +138,18 @@ public class CursorGranularizer
|
||||||
return DateTimes.utc(currentBucketStart);
|
return DateTimes.utc(currentBucketStart);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Interval getCurrentInterval()
|
||||||
|
{
|
||||||
|
return Intervals.utc(currentBucketStart, currentBucketEnd);
|
||||||
|
}
|
||||||
|
|
||||||
public boolean advanceToBucket(final Interval bucketInterval)
|
public boolean advanceToBucket(final Interval bucketInterval)
|
||||||
{
|
{
|
||||||
|
currentBucketStart = bucketInterval.getStartMillis();
|
||||||
|
currentBucketEnd = bucketInterval.getEndMillis();
|
||||||
if (cursor.isDone()) {
|
if (cursor.isDone()) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
currentBucketStart = bucketInterval.getStartMillis();
|
|
||||||
currentBucketEnd = bucketInterval.getEndMillis();
|
|
||||||
if (timeSelector == null) {
|
if (timeSelector == null) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,6 +89,12 @@ public class QueryContexts
|
||||||
public static final String UNCOVERED_INTERVALS_LIMIT_KEY = "uncoveredIntervalsLimit";
|
public static final String UNCOVERED_INTERVALS_LIMIT_KEY = "uncoveredIntervalsLimit";
|
||||||
public static final String MIN_TOP_N_THRESHOLD = "minTopNThreshold";
|
public static final String MIN_TOP_N_THRESHOLD = "minTopNThreshold";
|
||||||
public static final String CATALOG_VALIDATION_ENABLED = "catalogValidationEnabled";
|
public static final String CATALOG_VALIDATION_ENABLED = "catalogValidationEnabled";
|
||||||
|
// this flag controls whether the topN engine can use the 'pooled' algorithm when query granularity is set to
|
||||||
|
// anything other than 'ALL' and the cardinality + number of aggregators would require more size than is available
|
||||||
|
// in the buffers and so must reset the cursor to use multiple passes. This is likely slower than the default
|
||||||
|
// behavior of falling back to heap memory, but less dangerous since too large of a query can cause the heap to run
|
||||||
|
// out of memory
|
||||||
|
public static final String TOPN_USE_MULTI_PASS_POOLED_QUERY_GRANULARITY = "useTopNMultiPassPooledQueryGranularity";
|
||||||
/**
|
/**
|
||||||
* Context parameter to enable/disable the extended filtered sum rewrite logic.
|
* Context parameter to enable/disable the extended filtered sum rewrite logic.
|
||||||
*
|
*
|
||||||
|
|
|
@ -391,7 +391,7 @@ public class GroupByQueryEngine
|
||||||
if (delegate != null && delegate.hasNext()) {
|
if (delegate != null && delegate.hasNext()) {
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
if (!cursor.isDone() && granularizer.currentOffsetWithinBucket()) {
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
if (delegate != null) {
|
if (delegate != null) {
|
||||||
delegate.close();
|
delegate.close();
|
||||||
}
|
}
|
||||||
|
|
|
@ -113,6 +113,7 @@ public class AggregateTopNMetricFirstAlgorithm implements TopNAlgorithm<int[], T
|
||||||
try {
|
try {
|
||||||
// reset cursor since we call run again
|
// reset cursor since we call run again
|
||||||
params.getCursor().reset();
|
params.getCursor().reset();
|
||||||
|
params.getGranularizer().advanceToBucket(params.getGranularizer().getCurrentInterval());
|
||||||
// Run topN for all metrics for top N dimension values
|
// Run topN for all metrics for top N dimension values
|
||||||
allMetricsParam = allMetricAlgo.makeInitParams(params.getSelectorPlus(), params.getCursor(), params.getGranularizer());
|
allMetricsParam = allMetricAlgo.makeInitParams(params.getSelectorPlus(), params.getCursor(), params.getGranularizer());
|
||||||
allMetricAlgo.run(
|
allMetricAlgo.run(
|
||||||
|
|
|
@ -97,12 +97,14 @@ public abstract class BaseTopNAlgorithm<DimValSelector, DimValAggregateStore, Pa
|
||||||
}
|
}
|
||||||
boolean hasDimValSelector = (dimValSelector != null);
|
boolean hasDimValSelector = (dimValSelector != null);
|
||||||
|
|
||||||
int cardinality = params.getCardinality();
|
final int cardinality = params.getCardinality();
|
||||||
|
final int numValuesPerPass = params.getNumValuesPerPass();
|
||||||
int numProcessed = 0;
|
int numProcessed = 0;
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
while (numProcessed < cardinality) {
|
while (numProcessed < cardinality) {
|
||||||
final int numToProcess;
|
final int numToProcess;
|
||||||
int maxNumToProcess = Math.min(params.getNumValuesPerPass(), cardinality - numProcessed);
|
int maxNumToProcess = Math.min(numValuesPerPass, cardinality - numProcessed);
|
||||||
|
|
||||||
|
|
||||||
DimValSelector theDimValSelector;
|
DimValSelector theDimValSelector;
|
||||||
if (!hasDimValSelector) {
|
if (!hasDimValSelector) {
|
||||||
|
@ -125,6 +127,7 @@ public abstract class BaseTopNAlgorithm<DimValSelector, DimValAggregateStore, Pa
|
||||||
numProcessed += numToProcess;
|
numProcessed += numToProcess;
|
||||||
if (numProcessed < cardinality) {
|
if (numProcessed < cardinality) {
|
||||||
params.getCursor().reset();
|
params.getCursor().reset();
|
||||||
|
params.getGranularizer().advanceToBucket(params.getGranularizer().getCurrentInterval());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (queryMetrics != null) {
|
if (queryMetrics != null) {
|
||||||
|
|
|
@ -54,6 +54,7 @@ public final class Generic1AggPooledTopNScannerPrototype implements Generic1AggP
|
||||||
{
|
{
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
int positionToAllocate = 0;
|
int positionToAllocate = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDoneOrInterrupted()) {
|
while (!cursor.isDoneOrInterrupted()) {
|
||||||
final IndexedInts dimValues = dimensionSelector.getRow();
|
final IndexedInts dimValues = dimensionSelector.getRow();
|
||||||
final int dimSize = dimValues.size();
|
final int dimSize = dimValues.size();
|
||||||
|
@ -75,6 +76,7 @@ public final class Generic1AggPooledTopNScannerPrototype implements Generic1AggP
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -57,6 +57,7 @@ public final class Generic2AggPooledTopNScannerPrototype implements Generic2AggP
|
||||||
int totalAggregatorsSize = aggregator1Size + aggregator2Size;
|
int totalAggregatorsSize = aggregator1Size + aggregator2Size;
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
int positionToAllocate = 0;
|
int positionToAllocate = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDoneOrInterrupted()) {
|
while (!cursor.isDoneOrInterrupted()) {
|
||||||
final IndexedInts dimValues = dimensionSelector.getRow();
|
final IndexedInts dimValues = dimensionSelector.getRow();
|
||||||
final int dimSize = dimValues.size();
|
final int dimSize = dimValues.size();
|
||||||
|
@ -82,6 +83,7 @@ public final class Generic2AggPooledTopNScannerPrototype implements Generic2AggP
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -477,6 +477,7 @@ public class PooledTopNAlgorithm
|
||||||
final int aggExtra = aggSize % AGG_UNROLL_COUNT;
|
final int aggExtra = aggSize % AGG_UNROLL_COUNT;
|
||||||
int currentPosition = 0;
|
int currentPosition = 0;
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDoneOrInterrupted()) {
|
while (!cursor.isDoneOrInterrupted()) {
|
||||||
final IndexedInts dimValues = dimSelector.getRow();
|
final IndexedInts dimValues = dimSelector.getRow();
|
||||||
|
|
||||||
|
@ -669,6 +670,7 @@ public class PooledTopNAlgorithm
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -93,6 +93,7 @@ public class TimeExtractionTopNAlgorithm extends BaseTopNAlgorithm<int[], Map<Ob
|
||||||
final DimensionSelector dimSelector = params.getDimSelector();
|
final DimensionSelector dimSelector = params.getDimSelector();
|
||||||
|
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDone()) {
|
while (!cursor.isDone()) {
|
||||||
final Object key = dimensionValueConverter.apply(dimSelector.lookupName(dimSelector.getRow().get(0)));
|
final Object key = dimensionValueConverter.apply(dimSelector.lookupName(dimSelector.getRow().get(0)));
|
||||||
|
|
||||||
|
@ -109,6 +110,7 @@ public class TimeExtractionTopNAlgorithm extends BaseTopNAlgorithm<int[], Map<Ob
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -28,6 +28,7 @@ import org.apache.druid.java.util.common.guava.Sequence;
|
||||||
import org.apache.druid.java.util.common.guava.Sequences;
|
import org.apache.druid.java.util.common.guava.Sequences;
|
||||||
import org.apache.druid.query.ColumnSelectorPlus;
|
import org.apache.druid.query.ColumnSelectorPlus;
|
||||||
import org.apache.druid.query.CursorGranularizer;
|
import org.apache.druid.query.CursorGranularizer;
|
||||||
|
import org.apache.druid.query.QueryContexts;
|
||||||
import org.apache.druid.query.QueryMetrics;
|
import org.apache.druid.query.QueryMetrics;
|
||||||
import org.apache.druid.query.Result;
|
import org.apache.druid.query.Result;
|
||||||
import org.apache.druid.query.aggregation.AggregatorFactory;
|
import org.apache.druid.query.aggregation.AggregatorFactory;
|
||||||
|
@ -245,6 +246,11 @@ public class TopNQueryEngine
|
||||||
final int numBytesPerRecord
|
final int numBytesPerRecord
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
|
if (cardinality < 0) {
|
||||||
|
// unknown cardinality doesn't work with the pooled algorithm which requires an exact count of dictionary ids
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
if (selector.isHasExtractionFn()) {
|
if (selector.isHasExtractionFn()) {
|
||||||
// extraction functions can have a many to one mapping, and should use a heap algorithm
|
// extraction functions can have a many to one mapping, and should use a heap algorithm
|
||||||
return false;
|
return false;
|
||||||
|
@ -254,28 +260,35 @@ public class TopNQueryEngine
|
||||||
// non-string output cannot use the pooled algorith, even if the underlying selector supports it
|
// non-string output cannot use the pooled algorith, even if the underlying selector supports it
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!Types.is(capabilities, ValueType.STRING)) {
|
if (!Types.is(capabilities, ValueType.STRING)) {
|
||||||
// non-strings are not eligible to use the pooled algorithm, and should use a heap algorithm
|
// non-strings are not eligible to use the pooled algorithm, and should use a heap algorithm
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// string columns must use the on heap algorithm unless they have the following capabilites
|
|
||||||
if (!capabilities.isDictionaryEncoded().isTrue() || !capabilities.areDictionaryValuesUnique().isTrue()) {
|
if (!capabilities.isDictionaryEncoded().isTrue() || !capabilities.areDictionaryValuesUnique().isTrue()) {
|
||||||
|
// string columns must use the on heap algorithm unless they have the following capabilites
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (Granularities.ALL.equals(query.getGranularity())) {
|
|
||||||
// all other requirements have been satisfied, ALL granularity can always use the pooled algorithms
|
// num values per pass must be greater than 0 or else the pooled algorithm cannot progress
|
||||||
return true;
|
|
||||||
}
|
|
||||||
// if not using ALL granularity, we can still potentially use the pooled algorithm if we are certain it doesn't
|
|
||||||
// need to make multiple passes (e.g. reset the cursor)
|
|
||||||
try (final ResourceHolder<ByteBuffer> resultsBufHolder = bufferPool.take()) {
|
try (final ResourceHolder<ByteBuffer> resultsBufHolder = bufferPool.take()) {
|
||||||
final ByteBuffer resultsBuf = resultsBufHolder.get();
|
final ByteBuffer resultsBuf = resultsBufHolder.get();
|
||||||
|
|
||||||
final int numBytesToWorkWith = resultsBuf.capacity();
|
final int numBytesToWorkWith = resultsBuf.capacity();
|
||||||
final int numValuesPerPass = numBytesPerRecord > 0 ? numBytesToWorkWith / numBytesPerRecord : cardinality;
|
final int numValuesPerPass = numBytesPerRecord > 0 ? numBytesToWorkWith / numBytesPerRecord : cardinality;
|
||||||
|
|
||||||
return numValuesPerPass <= cardinality;
|
final boolean allowMultiPassPooled = query.context().getBoolean(
|
||||||
|
QueryContexts.TOPN_USE_MULTI_PASS_POOLED_QUERY_GRANULARITY,
|
||||||
|
false
|
||||||
|
);
|
||||||
|
if (Granularities.ALL.equals(query.getGranularity()) || allowMultiPassPooled) {
|
||||||
|
return numValuesPerPass > 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// if not using multi-pass for pooled + query granularity other than 'ALL', we must check that all values can fit
|
||||||
|
// in a single pass
|
||||||
|
return numValuesPerPass >= cardinality;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -94,6 +94,7 @@ public abstract class NullableNumericTopNColumnAggregatesProcessor<Selector exte
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDone()) {
|
while (!cursor.isDone()) {
|
||||||
if (hasNulls && selector.isNull()) {
|
if (hasNulls && selector.isNull()) {
|
||||||
if (nullValueAggregates == null) {
|
if (nullValueAggregates == null) {
|
||||||
|
@ -113,6 +114,7 @@ public abstract class NullableNumericTopNColumnAggregatesProcessor<Selector exte
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -150,6 +150,7 @@ public class StringTopNColumnAggregatesProcessor implements TopNColumnAggregates
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDone()) {
|
while (!cursor.isDone()) {
|
||||||
final IndexedInts dimValues = selector.getRow();
|
final IndexedInts dimValues = selector.getRow();
|
||||||
for (int i = 0, size = dimValues.size(); i < size; ++i) {
|
for (int i = 0, size = dimValues.size(); i < size; ++i) {
|
||||||
|
@ -173,6 +174,7 @@ public class StringTopNColumnAggregatesProcessor implements TopNColumnAggregates
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -192,6 +194,7 @@ public class StringTopNColumnAggregatesProcessor implements TopNColumnAggregates
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
long processedRows = 0;
|
long processedRows = 0;
|
||||||
|
if (granularizer.currentOffsetWithinBucket()) {
|
||||||
while (!cursor.isDone()) {
|
while (!cursor.isDone()) {
|
||||||
final IndexedInts dimValues = selector.getRow();
|
final IndexedInts dimValues = selector.getRow();
|
||||||
for (int i = 0, size = dimValues.size(); i < size; ++i) {
|
for (int i = 0, size = dimValues.size(); i < size; ++i) {
|
||||||
|
@ -210,6 +213,7 @@ public class StringTopNColumnAggregatesProcessor implements TopNColumnAggregates
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return processedRows;
|
return processedRows;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -60,6 +60,7 @@ import org.apache.druid.query.aggregation.FilteredAggregatorFactory;
|
||||||
import org.apache.druid.query.aggregation.FloatMaxAggregatorFactory;
|
import org.apache.druid.query.aggregation.FloatMaxAggregatorFactory;
|
||||||
import org.apache.druid.query.aggregation.FloatMinAggregatorFactory;
|
import org.apache.druid.query.aggregation.FloatMinAggregatorFactory;
|
||||||
import org.apache.druid.query.aggregation.LongSumAggregatorFactory;
|
import org.apache.druid.query.aggregation.LongSumAggregatorFactory;
|
||||||
|
import org.apache.druid.query.aggregation.any.StringAnyAggregatorFactory;
|
||||||
import org.apache.druid.query.aggregation.cardinality.CardinalityAggregatorFactory;
|
import org.apache.druid.query.aggregation.cardinality.CardinalityAggregatorFactory;
|
||||||
import org.apache.druid.query.aggregation.firstlast.first.DoubleFirstAggregatorFactory;
|
import org.apache.druid.query.aggregation.firstlast.first.DoubleFirstAggregatorFactory;
|
||||||
import org.apache.druid.query.aggregation.firstlast.first.FloatFirstAggregatorFactory;
|
import org.apache.druid.query.aggregation.firstlast.first.FloatFirstAggregatorFactory;
|
||||||
|
@ -6378,6 +6379,928 @@ public class TopNQueryRunnerTest extends InitializedNullHandlingTest
|
||||||
assertExpectedResults(expectedResults, query);
|
assertExpectedResults(expectedResults, query);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_empty_buckets()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(QueryRunnerTestHelper.MARKET_DIMENSION)
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(QueryRunnerTestHelper.INDEX_LONG_SUM)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"index", 2836L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"index", 2681L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"index", 1102L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"index", 2514L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"index", 2193L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"index", 1120L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_empty_buckets_expression()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.virtualColumns(
|
||||||
|
new ExpressionVirtualColumn(
|
||||||
|
"vc",
|
||||||
|
"market + ' ' + placement",
|
||||||
|
ColumnType.STRING,
|
||||||
|
TestExprMacroTable.INSTANCE
|
||||||
|
)
|
||||||
|
)
|
||||||
|
.dimension("vc")
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(QueryRunnerTestHelper.INDEX_LONG_SUM)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
"vc", "total_market preferred",
|
||||||
|
"index", 2836L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"vc", "upfront preferred",
|
||||||
|
"index", 2681L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"vc", "spot preferred",
|
||||||
|
"index", 1102L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
"vc", "total_market preferred",
|
||||||
|
"index", 2514L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"vc", "upfront preferred",
|
||||||
|
"index", 2193L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"vc", "spot preferred",
|
||||||
|
"index", 1120L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_empty_buckets_2pool()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(QueryRunnerTestHelper.MARKET_DIMENSION)
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(
|
||||||
|
QueryRunnerTestHelper.INDEX_LONG_SUM,
|
||||||
|
QueryRunnerTestHelper.INDEX_DOUBLE_MAX
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"index", 2836L,
|
||||||
|
"doubleMaxIndex", 1522.043733
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"index", 2681L,
|
||||||
|
"doubleMaxIndex", 1447.34116
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"index", 1102L,
|
||||||
|
"doubleMaxIndex", 158.747224
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"index", 2514L,
|
||||||
|
"doubleMaxIndex", 1321.375057
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"index", 2193L,
|
||||||
|
"doubleMaxIndex", 1144.342401
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"index", 1120L,
|
||||||
|
"doubleMaxIndex", 166.016049
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_empty_buckets_timeExtract()
|
||||||
|
{
|
||||||
|
// this is pretty wierd to have both query granularity and a time extractionFn... but it is not explicitly
|
||||||
|
// forbidden so might as well test it
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(
|
||||||
|
new ExtractionDimensionSpec(
|
||||||
|
ColumnHolder.TIME_COLUMN_NAME,
|
||||||
|
"dayOfWeek",
|
||||||
|
new TimeFormatExtractionFn("EEEE", null, null, null, false)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(
|
||||||
|
QueryRunnerTestHelper.INDEX_LONG_SUM
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Collections.singletonList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
"dayOfWeek", "Friday",
|
||||||
|
"index", 6619L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Collections.singletonList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
"dayOfWeek", "Saturday",
|
||||||
|
"index", 5827L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_empty_buckets_numeric()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(new DefaultDimensionSpec("qualityLong", "qualityLong", ColumnType.LONG))
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(
|
||||||
|
QueryRunnerTestHelper.INDEX_LONG_SUM
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1600L,
|
||||||
|
"index", 2900L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1400L,
|
||||||
|
"index", 2870L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1200L,
|
||||||
|
"index", 158L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1000L,
|
||||||
|
"index", 135L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1500L,
|
||||||
|
"index", 121L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1300L,
|
||||||
|
"index", 120L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1800L,
|
||||||
|
"index", 119L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1100L,
|
||||||
|
"index", 118L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1700L,
|
||||||
|
"index", 78L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1600L,
|
||||||
|
"index", 2505L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1400L,
|
||||||
|
"index", 2447L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1200L,
|
||||||
|
"index", 166L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1000L,
|
||||||
|
"index", 147L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1800L,
|
||||||
|
"index", 126L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1500L,
|
||||||
|
"index", 114L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1300L,
|
||||||
|
"index", 113L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1100L,
|
||||||
|
"index", 112L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
"qualityLong", 1700L,
|
||||||
|
"index", 97L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_multipass_no_pool()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(QueryRunnerTestHelper.MARKET_DIMENSION)
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(
|
||||||
|
QueryRunnerTestHelper.INDEX_LONG_SUM,
|
||||||
|
new StringAnyAggregatorFactory("big", QueryRunnerTestHelper.PLACEMENT_DIMENSION, 4000000, null)
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2836L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2681L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 1102L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2514L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2193L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 1120L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_multipass_with_pooled()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(QueryRunnerTestHelper.MARKET_DIMENSION)
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.context(ImmutableMap.of(QueryContexts.TOPN_USE_MULTI_PASS_POOLED_QUERY_GRANULARITY, true))
|
||||||
|
.aggregators(
|
||||||
|
QueryRunnerTestHelper.INDEX_LONG_SUM,
|
||||||
|
new StringAnyAggregatorFactory("big", QueryRunnerTestHelper.PLACEMENT_DIMENSION, 4000000, null)
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2836L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2681L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 1102L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2514L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2193L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 1120L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testTopN_time_granularity_uses_heap_if_too_big()
|
||||||
|
{
|
||||||
|
assumeTimeOrdered();
|
||||||
|
TopNQuery query = new TopNQueryBuilder()
|
||||||
|
.dataSource(QueryRunnerTestHelper.DATA_SOURCE)
|
||||||
|
.granularity(Granularities.HOUR)
|
||||||
|
.dimension(QueryRunnerTestHelper.MARKET_DIMENSION)
|
||||||
|
.metric(QueryRunnerTestHelper.INDEX_METRIC)
|
||||||
|
.threshold(10_000)
|
||||||
|
.intervals(QueryRunnerTestHelper.FIRST_TO_THIRD)
|
||||||
|
.aggregators(
|
||||||
|
QueryRunnerTestHelper.INDEX_LONG_SUM,
|
||||||
|
new StringAnyAggregatorFactory("big", QueryRunnerTestHelper.PLACEMENT_DIMENSION, 40000000, null)
|
||||||
|
)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
List<Result<TopNResultValue>> expectedResults = Arrays.asList(
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-01T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2836L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2681L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 1102L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-01T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(
|
||||||
|
DateTimes.of("2011-04-02T00:00:00.000Z"),
|
||||||
|
TopNResultValue.create(
|
||||||
|
Arrays.<Map<String, Object>>asList(
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "total_market",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2514L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "upfront",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 2193L
|
||||||
|
),
|
||||||
|
ImmutableMap.of(
|
||||||
|
QueryRunnerTestHelper.MARKET_DIMENSION, "spot",
|
||||||
|
"big", "preferred",
|
||||||
|
"index", 1120L
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T01:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T02:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T03:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T04:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T05:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T06:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T07:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T08:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T09:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T10:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T11:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T12:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T13:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T14:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T15:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T16:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T17:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T18:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T19:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T20:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T21:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T22:00:00.000Z"), TopNResultValue.create(Collections.emptyList())),
|
||||||
|
new Result<>(DateTimes.of("2011-04-02T23:00:00.000Z"), TopNResultValue.create(Collections.emptyList()))
|
||||||
|
);
|
||||||
|
|
||||||
|
assertExpectedResults(expectedResults, query);
|
||||||
|
}
|
||||||
|
|
||||||
private void assumeTimeOrdered()
|
private void assumeTimeOrdered()
|
||||||
{
|
{
|
||||||
try (final CursorHolder cursorHolder =
|
try (final CursorHolder cursorHolder =
|
||||||
|
|
Loading…
Reference in New Issue