|
15 | 15 | import org.elasticsearch.common.xcontent.XContentBuilder; |
16 | 16 | import org.elasticsearch.common.xcontent.XContentParser; |
17 | 17 | import org.elasticsearch.index.query.QueryBuilder; |
| 18 | +import org.elasticsearch.index.query.RangeQueryBuilder; |
18 | 19 | import org.elasticsearch.index.query.TermsQueryBuilder; |
19 | 20 | import org.elasticsearch.search.aggregations.Aggregations; |
20 | 21 | import org.elasticsearch.search.aggregations.bucket.composite.CompositeAggregation; |
21 | 22 | import org.elasticsearch.search.aggregations.bucket.composite.CompositeAggregationBuilder; |
| 23 | +import org.elasticsearch.search.aggregations.bucket.histogram.DateHistogramInterval; |
22 | 24 | import org.elasticsearch.search.builder.SearchSourceBuilder; |
23 | 25 | import org.elasticsearch.test.ESTestCase; |
| 26 | +import org.elasticsearch.xpack.core.transform.transforms.pivot.DateHistogramGroupSource; |
24 | 27 | import org.elasticsearch.xpack.core.transform.transforms.pivot.GeoTileGroupSourceTests; |
25 | 28 | import org.elasticsearch.xpack.core.transform.transforms.pivot.GroupConfig; |
26 | 29 | import org.elasticsearch.xpack.core.transform.transforms.pivot.GroupConfigTests; |
|
43 | 46 | import static org.elasticsearch.common.xcontent.XContentFactory.jsonBuilder; |
44 | 47 | import static org.hamcrest.CoreMatchers.instanceOf; |
45 | 48 | import static org.hamcrest.Matchers.containsInAnyOrder; |
| 49 | +import static org.hamcrest.Matchers.equalTo; |
46 | 50 | import static org.mockito.Mockito.mock; |
47 | 51 | import static org.mockito.Mockito.when; |
48 | 52 |
|
@@ -138,6 +142,60 @@ public void testTermsFieldCollector() throws IOException { |
138 | 142 | assertThat(((TermsQueryBuilder) queryBuilder).values(), containsInAnyOrder("id1", "id2", "id3")); |
139 | 143 | } |
140 | 144 |
|
| 145 | + public void testDateHistogramFieldCollector() throws IOException { |
| 146 | + Map<String, SingleGroupSource> groups = new LinkedHashMap<>(); |
| 147 | + |
| 148 | + SingleGroupSource groupBy = new DateHistogramGroupSource( |
| 149 | + "timestamp", |
| 150 | + null, |
| 151 | + false, |
| 152 | + new DateHistogramGroupSource.FixedInterval(DateHistogramInterval.MINUTE), |
| 153 | + null |
| 154 | + ); |
| 155 | + groups.put("output_timestamp", groupBy); |
| 156 | + |
| 157 | + ChangeCollector collector = CompositeBucketsChangeCollector.buildChangeCollector( |
| 158 | + getCompositeAggregation(groups), |
| 159 | + groups, |
| 160 | + "timestamp" |
| 161 | + ); |
| 162 | + |
| 163 | + QueryBuilder queryBuilder = collector.buildFilterQuery(66_666, 200_222); |
| 164 | + assertNotNull(queryBuilder); |
| 165 | + assertThat(queryBuilder, instanceOf(RangeQueryBuilder.class)); |
| 166 | + // rounded down |
| 167 | + assertThat(((RangeQueryBuilder) queryBuilder).from(), equalTo(Long.valueOf(60_000))); |
| 168 | + assertTrue(((RangeQueryBuilder) queryBuilder).includeLower()); |
| 169 | + assertThat(((RangeQueryBuilder) queryBuilder).fieldName(), equalTo("timestamp")); |
| 170 | + |
| 171 | + // timestamp field does not match |
| 172 | + collector = CompositeBucketsChangeCollector.buildChangeCollector(getCompositeAggregation(groups), groups, "sync_timestamp"); |
| 173 | + |
| 174 | + queryBuilder = collector.buildFilterQuery(66_666, 200_222); |
| 175 | + assertNull(queryBuilder); |
| 176 | + |
| 177 | + // field does not match, but output field equals sync field |
| 178 | + collector = CompositeBucketsChangeCollector.buildChangeCollector(getCompositeAggregation(groups), groups, "output_timestamp"); |
| 179 | + |
| 180 | + queryBuilder = collector.buildFilterQuery(66_666, 200_222); |
| 181 | + assertNull(queryBuilder); |
| 182 | + |
| 183 | + // missing bucket disables optimization |
| 184 | + groupBy = new DateHistogramGroupSource( |
| 185 | + "timestamp", |
| 186 | + null, |
| 187 | + true, |
| 188 | + new DateHistogramGroupSource.FixedInterval(DateHistogramInterval.MINUTE), |
| 189 | + null |
| 190 | + ); |
| 191 | + groups.put("output_timestamp", groupBy); |
| 192 | + |
| 193 | + collector = CompositeBucketsChangeCollector.buildChangeCollector(getCompositeAggregation(groups), groups, "timestamp"); |
| 194 | + |
| 195 | + queryBuilder = collector.buildFilterQuery(66_666, 200_222); |
| 196 | + assertNull(queryBuilder); |
| 197 | + } |
| 198 | + |
141 | 199 | private static CompositeAggregationBuilder getCompositeAggregation(Map<String, SingleGroupSource> groups) throws IOException { |
142 | 200 | CompositeAggregationBuilder compositeAggregation; |
143 | 201 | try (XContentBuilder builder = jsonBuilder()) { |
|
0 commit comments