1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/lib/metrics.test.js

73 lines
2.0 KiB
JavaScript
Raw Normal View History

2016-12-04 14:09:37 +01:00
'use strict';
2018-12-17 09:24:49 +01:00
const test = require('ava');
const { EventEmitter } = require('events');
const eventBus = new EventEmitter();
const eventStore = new EventEmitter();
const clientMetricsStore = new EventEmitter();
const { REQUEST_TIME, DB_TIME } = require('./events');
const { FEATURE_UPDATED } = require('./event-type');
const { startMonitoring } = require('./metrics');
2017-06-28 14:21:05 +02:00
const { register: prometheusRegister } = require('prom-client');
test.before(() => {
startMonitoring(true, eventBus, eventStore, clientMetricsStore);
});
test('should collect metrics for requests', t => {
2017-06-28 10:17:14 +02:00
eventBus.emit(REQUEST_TIME, {
path: 'somePath',
method: 'GET',
statusCode: 200,
time: 1337,
});
2016-12-04 14:09:37 +01:00
const metrics = prometheusRegister.metrics();
2017-06-28 10:17:14 +02:00
t.regex(
metrics,
2017-08-23 11:27:58 +02:00
/http_request_duration_milliseconds{quantile="0\.99",path="somePath",method="GET",status="200"} 1337/
2017-06-28 10:17:14 +02:00
);
2016-12-04 14:09:37 +01:00
});
test('should collect metrics for updated toggles', t => {
eventStore.emit(FEATURE_UPDATED, {
data: { name: 'TestToggle' },
});
const metrics = prometheusRegister.metrics();
t.regex(metrics, /feature_toggle_update_total{toggle="TestToggle"} 1/);
});
test('should collect metrics for client metric reports', t => {
clientMetricsStore.emit('metrics', {
bucket: {
toggles: {
TestToggle: {
yes: 10,
no: 5,
},
},
},
});
const metrics = prometheusRegister.metrics();
t.regex(
metrics,
2019-12-18 15:21:36 +01:00
/feature_toggle_usage_total{toggle="TestToggle",active="true",appName="undefined"} 10\nfeature_toggle_usage_total{toggle="TestToggle",active="false",appName="undefined"} 5/
);
});
test('should collect metrics for db query timings', t => {
eventBus.emit(DB_TIME, {
store: 'foo',
action: 'bar',
time: 0.1337,
});
const metrics = prometheusRegister.metrics();
t.regex(
metrics,
/db_query_duration_seconds{quantile="0\.99",store="foo",action="bar"} 0.1337/
);
});