From bb8c0cb50b2b7b89dda4f26b7c46b7878b6a21a1 Mon Sep 17 00:00:00 2001 From: nishant Date: Tue, 21 Apr 2015 09:31:13 +0530 Subject: [PATCH] Improve filtering of segments for dataSourceMetadataQuery dataSourceMetadataQuery only needs to be executed on latest segments at present, modify filterSegments and add test. --- .../DataSourceQueryQueryToolChest.java | 4 +-- .../DataSourceMetadataQueryTest.java | 33 +++++++++++-------- 2 files changed, 21 insertions(+), 16 deletions(-) diff --git a/processing/src/main/java/io/druid/query/datasourcemetadata/DataSourceQueryQueryToolChest.java b/processing/src/main/java/io/druid/query/datasourcemetadata/DataSourceQueryQueryToolChest.java index b84bb4f6eeb..05418096f38 100644 --- a/processing/src/main/java/io/druid/query/datasourcemetadata/DataSourceQueryQueryToolChest.java +++ b/processing/src/main/java/io/druid/query/datasourcemetadata/DataSourceQueryQueryToolChest.java @@ -58,7 +58,6 @@ public class DataSourceQueryQueryToolChest return segments; } - final T min = segments.get(0); final T max = segments.get(segments.size() - 1); return Lists.newArrayList( @@ -69,8 +68,7 @@ public class DataSourceQueryQueryToolChest @Override public boolean apply(T input) { - return (min != null && input.getInterval().overlaps(min.getInterval())) || - (max != null && input.getInterval().overlaps(max.getInterval())); + return max != null && input.getInterval().overlaps(max.getInterval()); } } ) diff --git a/processing/src/test/java/io/druid/query/datasourcemetadata/DataSourceMetadataQueryTest.java b/processing/src/test/java/io/druid/query/datasourcemetadata/DataSourceMetadataQueryTest.java index 447d835ee30..9902e0f8ab6 100644 --- a/processing/src/test/java/io/druid/query/datasourcemetadata/DataSourceMetadataQueryTest.java +++ b/processing/src/test/java/io/druid/query/datasourcemetadata/DataSourceMetadataQueryTest.java @@ -35,7 +35,6 @@ import io.druid.query.QueryRunnerTestHelper; import io.druid.query.Result; import io.druid.query.aggregation.AggregatorFactory; import io.druid.query.aggregation.CountAggregatorFactory; -import io.druid.query.timeboundary.TimeBoundaryQueryQueryToolChest; import io.druid.segment.IncrementalIndexSegment; import io.druid.segment.incremental.IncrementalIndex; import io.druid.segment.incremental.OnheapIncrementalIndex; @@ -142,9 +141,25 @@ public class DataSourceMetadataQueryTest @Test public void testFilterSegments() { - List segments = new TimeBoundaryQueryQueryToolChest().filterSegments( + List segments = new DataSourceQueryQueryToolChest().filterSegments( null, Arrays.asList( + new LogicalSegment() + { + @Override + public Interval getInterval() + { + return new Interval("2012-01-01/P1D"); + } + }, + new LogicalSegment() + { + @Override + public Interval getInterval() + { + return new Interval("2012-01-01T01/PT1H"); + } + }, new LogicalSegment() { @Override @@ -172,8 +187,8 @@ public class DataSourceMetadataQueryTest ) ); - Assert.assertEquals(segments.size(), 3); - + Assert.assertEquals(segments.size(), 2); + // should only have the latest segments. List expected = Arrays.asList( new LogicalSegment() { @@ -184,14 +199,6 @@ public class DataSourceMetadataQueryTest } }, new LogicalSegment() - { - @Override - public Interval getInterval() - { - return new Interval("2013-01-01T01/PT1H"); - } - }, - new LogicalSegment() { @Override public Interval getInterval() @@ -202,7 +209,7 @@ public class DataSourceMetadataQueryTest ); for (int i = 0; i < segments.size(); i++) { - Assert.assertEquals(segments.get(i).getInterval(), expected.get(i).getInterval()); + Assert.assertEquals(expected.get(i).getInterval(),segments.get(i).getInterval()); } }