grafana/public/app/plugins/datasource/elasticsearch/specs/elastic_response_specs.ts

725 lines
19 KiB
TypeScript
Raw Normal View History

2017-12-20 05:33:33 -06:00
import { describe, beforeEach, it, expect } from 'test/lib/common';
import { ElasticResponse } from '../elastic_response';
2017-12-20 05:33:33 -06:00
describe('ElasticResponse', function() {
var targets;
var response;
var result;
2017-12-20 05:33:33 -06:00
describe('simple query and count', function() {
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'count', id: '1' }],
bucketAggs: [
{ type: 'date_histogram', field: '@timestamp', id: '2' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 1000,
},
{
doc_count: 15,
2017-12-20 05:33:33 -06:00
key: 2000,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 1 series', function() {
expect(result.data.length).to.be(1);
2017-12-20 05:33:33 -06:00
expect(result.data[0].target).to.be('Count');
expect(result.data[0].datapoints.length).to.be(2);
expect(result.data[0].datapoints[0][0]).to.be(10);
expect(result.data[0].datapoints[0][1]).to.be(1000);
});
});
2017-12-20 05:33:33 -06:00
describe('simple query count & avg aggregation', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [
2017-12-20 05:33:33 -06:00
{ type: 'count', id: '1' },
{ type: 'avg', field: 'value', id: '2' },
],
bucketAggs: [
{ type: 'date_histogram', field: '@timestamp', id: '3' },
],
2017-12-20 05:33:33 -06:00
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'2': { value: 88 },
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 1000,
},
{
2017-12-20 05:33:33 -06:00
'2': { value: 99 },
doc_count: 15,
2017-12-20 05:33:33 -06:00
key: 2000,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 2 series', function() {
expect(result.data.length).to.be(2);
expect(result.data[0].datapoints.length).to.be(2);
expect(result.data[0].datapoints[0][0]).to.be(10);
expect(result.data[0].datapoints[0][1]).to.be(1000);
2017-12-20 05:33:33 -06:00
expect(result.data[1].target).to.be('Average value');
expect(result.data[1].datapoints[0][0]).to.be(88);
expect(result.data[1].datapoints[1][0]).to.be(99);
});
});
2017-12-20 05:33:33 -06:00
describe('single group by query one metric', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'count', id: '1' }],
bucketAggs: [
2017-12-20 05:33:33 -06:00
{ type: 'terms', field: 'host', id: '2' },
{ type: 'date_histogram', field: '@timestamp', id: '3' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{ doc_count: 1, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 3, key: 2000 },
],
},
doc_count: 4,
2017-12-20 05:33:33 -06:00
key: 'server1',
},
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{ doc_count: 2, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 8, key: 2000 },
],
},
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 'server2',
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 2 series', function() {
expect(result.data.length).to.be(2);
expect(result.data[0].datapoints.length).to.be(2);
2017-12-20 05:33:33 -06:00
expect(result.data[0].target).to.be('server1');
expect(result.data[1].target).to.be('server2');
});
});
2017-12-20 05:33:33 -06:00
describe('single group by query two metrics', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [
2017-12-20 05:33:33 -06:00
{ type: 'count', id: '1' },
{ type: 'avg', field: '@value', id: '4' },
],
bucketAggs: [
2017-12-20 05:33:33 -06:00
{ type: 'terms', field: 'host', id: '2' },
{ type: 'date_histogram', field: '@timestamp', id: '3' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
2017-12-20 05:33:33 -06:00
{ '4': { value: 10 }, doc_count: 1, key: 1000 },
{ '4': { value: 12 }, doc_count: 3, key: 2000 },
],
},
doc_count: 4,
2017-12-20 05:33:33 -06:00
key: 'server1',
},
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
2017-12-20 05:33:33 -06:00
{ '4': { value: 20 }, doc_count: 1, key: 1000 },
{ '4': { value: 32 }, doc_count: 3, key: 2000 },
],
},
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 'server2',
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 2 series', function() {
expect(result.data.length).to.be(4);
expect(result.data[0].datapoints.length).to.be(2);
2017-12-20 05:33:33 -06:00
expect(result.data[0].target).to.be('server1 Count');
expect(result.data[1].target).to.be('server1 Average @value');
expect(result.data[2].target).to.be('server2 Count');
expect(result.data[3].target).to.be('server2 Average @value');
});
});
2017-12-20 05:33:33 -06:00
describe('with percentiles ', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [
2017-12-20 05:33:33 -06:00
{ type: 'percentiles', settings: { percents: [75, 90] }, id: '1' },
],
2017-12-20 05:33:33 -06:00
bucketAggs: [
{ type: 'date_histogram', field: '@timestamp', id: '3' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'1': { values: { '75': 3.3, '90': 5.5 } },
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 1000,
},
{
2017-12-20 05:33:33 -06:00
'1': { values: { '75': 2.3, '90': 4.5 } },
doc_count: 15,
2017-12-20 05:33:33 -06:00
key: 2000,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 2 series', function() {
expect(result.data.length).to.be(2);
expect(result.data[0].datapoints.length).to.be(2);
2017-12-20 05:33:33 -06:00
expect(result.data[0].target).to.be('p75');
expect(result.data[1].target).to.be('p90');
expect(result.data[0].datapoints[0][0]).to.be(3.3);
expect(result.data[0].datapoints[0][1]).to.be(1000);
expect(result.data[1].datapoints[1][0]).to.be(4.5);
});
});
2017-12-20 05:33:33 -06:00
describe('with extended_stats', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [
{
2017-12-20 05:33:33 -06:00
type: 'extended_stats',
meta: { max: true, std_deviation_bounds_upper: true },
2017-12-20 05:33:33 -06:00
id: '1',
},
],
bucketAggs: [
2017-12-20 05:33:33 -06:00
{ type: 'terms', field: 'host', id: '3' },
{ type: 'date_histogram', id: '4' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{
2017-12-20 05:33:33 -06:00
key: 'server1',
'4': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'1': {
max: 10.2,
min: 5.5,
2017-12-20 05:33:33 -06:00
std_deviation_bounds: { upper: 3, lower: -2 },
},
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 1000,
},
],
},
},
{
2017-12-20 05:33:33 -06:00
key: 'server2',
'4': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'1': {
max: 10.2,
min: 5.5,
2017-12-20 05:33:33 -06:00
std_deviation_bounds: { upper: 3, lower: -2 },
},
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 1000,
},
],
},
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 4 series', function() {
expect(result.data.length).to.be(4);
expect(result.data[0].datapoints.length).to.be(1);
2017-12-20 05:33:33 -06:00
expect(result.data[0].target).to.be('server1 Max');
expect(result.data[1].target).to.be('server1 Std Dev Upper');
expect(result.data[0].datapoints[0][0]).to.be(10.2);
expect(result.data[1].datapoints[0][0]).to.be(3);
});
});
2017-12-20 05:33:33 -06:00
describe('single group by with alias pattern', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'count', id: '1' }],
alias: '{{term @host}} {{metric}} and {{not_exist}} {{@host}}',
bucketAggs: [
2017-12-20 05:33:33 -06:00
{ type: 'terms', field: '@host', id: '2' },
{ type: 'date_histogram', field: '@timestamp', id: '3' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{ doc_count: 1, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 3, key: 2000 },
],
},
doc_count: 4,
2017-12-20 05:33:33 -06:00
key: 'server1',
},
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{ doc_count: 2, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 8, key: 2000 },
],
},
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 'server2',
},
{
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{ doc_count: 2, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 8, key: 2000 },
],
},
doc_count: 10,
2017-12-20 05:33:33 -06:00
key: 0,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 2 series', function() {
expect(result.data.length).to.be(3);
expect(result.data[0].datapoints.length).to.be(2);
expect(result.data[0].target).to.be(
2017-12-20 05:33:33 -06:00
'server1 Count and {{not_exist}} server1'
);
expect(result.data[1].target).to.be(
2017-12-20 05:33:33 -06:00
'server2 Count and {{not_exist}} server2'
);
2017-12-20 05:33:33 -06:00
expect(result.data[2].target).to.be('0 Count and {{not_exist}} 0');
});
});
2017-12-20 05:33:33 -06:00
describe('histogram response', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'count', id: '1' }],
bucketAggs: [{ type: 'histogram', field: 'bytes', id: '3' }],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'3': {
buckets: [
{ doc_count: 1, key: 1000 },
{ doc_count: 3, key: 2000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 2, key: 1000 },
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return table with byte and count', function() {
expect(result.data[0].rows.length).to.be(3);
expect(result.data[0].columns).to.eql([
2017-12-20 05:33:33 -06:00
{ text: 'bytes', filterable: true },
{ text: 'Count' },
]);
});
});
2017-12-20 05:33:33 -06:00
describe('with two filters agg', function() {
var result;
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'count', id: '1' }],
bucketAggs: [
{
2017-12-20 05:33:33 -06:00
id: '2',
type: 'filters',
settings: {
filters: [
2017-12-20 05:33:33 -06:00
{ query: '@metric:cpu' },
{ query: '@metric:logins.count' },
],
},
},
2017-12-20 05:33:33 -06:00
{ type: 'date_histogram', field: '@timestamp', id: '3' },
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: {
2017-12-20 05:33:33 -06:00
'@metric:cpu': {
'3': {
buckets: [
{ doc_count: 1, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 3, key: 2000 },
],
},
},
2017-12-20 05:33:33 -06:00
'@metric:logins.count': {
'3': {
buckets: [
{ doc_count: 2, key: 1000 },
2017-12-20 05:33:33 -06:00
{ doc_count: 8, key: 2000 },
],
},
},
},
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return 2 series', function() {
expect(result.data.length).to.be(2);
expect(result.data[0].datapoints.length).to.be(2);
2017-12-20 05:33:33 -06:00
expect(result.data[0].target).to.be('@metric:cpu');
expect(result.data[1].target).to.be('@metric:logins.count');
});
});
2017-12-20 05:33:33 -06:00
describe('with dropfirst and last aggregation', function() {
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'avg', id: '1' }, { type: 'count' }],
bucketAggs: [
{
2017-12-20 05:33:33 -06:00
id: '2',
type: 'date_histogram',
field: 'host',
settings: { trimEdges: 1 },
},
],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'1': { value: 1000 },
key: 1,
2017-12-20 05:33:33 -06:00
doc_count: 369,
},
{
2017-12-20 05:33:33 -06:00
'1': { value: 2000 },
key: 2,
2017-12-20 05:33:33 -06:00
doc_count: 200,
},
{
2017-12-20 05:33:33 -06:00
'1': { value: 2000 },
key: 3,
2017-12-20 05:33:33 -06:00
doc_count: 200,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should remove first and last value', function() {
expect(result.data.length).to.be(2);
expect(result.data[0].datapoints.length).to.be(1);
});
});
2017-12-20 05:33:33 -06:00
describe('No group by time', function() {
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'avg', id: '1' }, { type: 'count' }],
bucketAggs: [{ id: '2', type: 'terms', field: 'host' }],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'1': { value: 1000 },
key: 'server-1',
doc_count: 369,
},
{
2017-12-20 05:33:33 -06:00
'1': { value: 2000 },
key: 'server-2',
doc_count: 200,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return table', function() {
expect(result.data.length).to.be(1);
2017-12-20 05:33:33 -06:00
expect(result.data[0].type).to.be('table');
expect(result.data[0].rows.length).to.be(2);
2017-12-20 05:33:33 -06:00
expect(result.data[0].rows[0][0]).to.be('server-1');
expect(result.data[0].rows[0][1]).to.be(1000);
expect(result.data[0].rows[0][2]).to.be(369);
2017-12-20 05:33:33 -06:00
expect(result.data[0].rows[1][0]).to.be('server-2');
expect(result.data[0].rows[1][1]).to.be(2000);
});
});
2017-12-20 05:33:33 -06:00
describe('Multiple metrics of same type', function() {
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [
2017-12-20 05:33:33 -06:00
{ type: 'avg', id: '1', field: 'test' },
{ type: 'avg', id: '2', field: 'test2' },
],
2017-12-20 05:33:33 -06:00
bucketAggs: [{ id: '2', type: 'terms', field: 'host' }],
},
];
response = {
responses: [
{
aggregations: {
2017-12-20 05:33:33 -06:00
'2': {
buckets: [
{
2017-12-20 05:33:33 -06:00
'1': { value: 1000 },
'2': { value: 3000 },
key: 'server-1',
doc_count: 369,
},
],
},
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should include field in metric name', function() {
expect(result.data[0].type).to.be('table');
expect(result.data[0].rows[0][1]).to.be(1000);
expect(result.data[0].rows[0][2]).to.be(3000);
});
});
2017-12-20 05:33:33 -06:00
describe('Raw documents query', function() {
beforeEach(function() {
targets = [
{
2017-12-20 05:33:33 -06:00
refId: 'A',
metrics: [{ type: 'raw_document', id: '1' }],
bucketAggs: [],
},
];
response = {
responses: [
{
hits: {
total: 100,
hits: [
{
2017-12-20 05:33:33 -06:00
_id: '1',
_type: 'type',
_index: 'index',
_source: { sourceProp: 'asd' },
fields: { fieldProp: 'field' },
},
{
2017-12-20 05:33:33 -06:00
_source: { sourceProp: 'asd2' },
fields: { fieldProp: 'field2' },
},
],
},
},
],
};
result = new ElasticResponse(targets, response).getTimeSeries();
});
2017-12-20 05:33:33 -06:00
it('should return docs', function() {
expect(result.data.length).to.be(1);
2017-12-20 05:33:33 -06:00
expect(result.data[0].type).to.be('docs');
expect(result.data[0].total).to.be(100);
expect(result.data[0].datapoints.length).to.be(2);
2017-12-20 05:33:33 -06:00
expect(result.data[0].datapoints[0].sourceProp).to.be('asd');
expect(result.data[0].datapoints[0].fieldProp).to.be('field');
});
});
});