|
|
@@ -9,29 +9,29 @@ define([
|
|
|
var builder = new ElasticQueryBuilder();
|
|
|
|
|
|
var query = builder.build({
|
|
|
- metrics: [{type: 'Count'}],
|
|
|
+ metrics: [{type: 'Count', id: '0'}],
|
|
|
timeField: '@timestamp',
|
|
|
- bucketAggs: [{type: 'date_histogram', field: '@timestamp'}],
|
|
|
+ bucketAggs: [{type: 'date_histogram', field: '@timestamp', id: '1'}],
|
|
|
});
|
|
|
|
|
|
expect(query.query.filtered.filter.bool.must[0].range["@timestamp"].gte).to.be("$timeFrom");
|
|
|
- expect(query.aggs["b0"].date_histogram.extended_bounds.min).to.be("$timeFrom");
|
|
|
+ expect(query.aggs["1"].date_histogram.extended_bounds.min).to.be("$timeFrom");
|
|
|
});
|
|
|
|
|
|
it('with multiple bucket aggs', function() {
|
|
|
var builder = new ElasticQueryBuilder();
|
|
|
|
|
|
var query = builder.build({
|
|
|
- metrics: [{type: 'Count'}],
|
|
|
+ metrics: [{type: 'count', id: '1'}],
|
|
|
timeField: '@timestamp',
|
|
|
bucketAggs: [
|
|
|
- {type: 'terms', field: '@host'},
|
|
|
- {type: 'date_histogram', field: '@timestamp'}
|
|
|
+ {type: 'terms', field: '@host', id: '2'},
|
|
|
+ {type: 'date_histogram', field: '@timestamp', id: '3'}
|
|
|
],
|
|
|
});
|
|
|
|
|
|
- expect(query.aggs["b0"].terms.field).to.be("@host");
|
|
|
- expect(query.aggs["b0"].aggs["b1"].date_histogram.field).to.be("@timestamp");
|
|
|
+ expect(query.aggs["2"].terms.field).to.be("@host");
|
|
|
+ expect(query.aggs["2"].aggs["3"].date_histogram.field).to.be("@timestamp");
|
|
|
});
|
|
|
|
|
|
|
|
|
@@ -39,14 +39,31 @@ define([
|
|
|
var builder = new ElasticQueryBuilder();
|
|
|
|
|
|
var query = builder.build({
|
|
|
- metrics: [{type: 'avg', field: '@value'}],
|
|
|
- bucketAggs: [{type: 'date_histogram', field: '@timestamp'}],
|
|
|
+ metrics: [{type: 'avg', field: '@value', id: '1'}],
|
|
|
+ bucketAggs: [{type: 'date_histogram', field: '@timestamp', id: '2'}],
|
|
|
}, 100, 1000);
|
|
|
|
|
|
- var aggs = query.aggs["b0"].aggs;
|
|
|
- expect(aggs["m0"].avg.field).to.be("@value");
|
|
|
+ var aggs = query.aggs["2"].aggs;
|
|
|
+ expect(aggs["1"].avg.field).to.be("@value");
|
|
|
});
|
|
|
|
|
|
+ it('with term agg and order by metric agg', function() {
|
|
|
+ var builder = new ElasticQueryBuilder();
|
|
|
+
|
|
|
+ var query = builder.build({
|
|
|
+ metrics: [{type: 'avg', field: '@value', id: '1'}],
|
|
|
+ bucketAggs: [
|
|
|
+ {type: 'term', size: 5, order: 'asc', orderBy: 'm0', id: '2' },
|
|
|
+ {type: 'date_histogram', field: '@timestamp', id: '3'}
|
|
|
+ ],
|
|
|
+ }, 100, 1000);
|
|
|
+
|
|
|
+ var firstLevel = query.aggs["2"];
|
|
|
+ var secondLevel = firstLevel.aggs["3"];
|
|
|
+
|
|
|
+ // expect(firstLevel.aggs["m0"].avg.field).to.be("@value");
|
|
|
+ expect(secondLevel.aggs["1"].avg.field).to.be("@value");
|
|
|
+ });
|
|
|
|
|
|
});
|
|
|
|