1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/src/lib/metrics.test.js
Christopher Kolstad 8bf4214ddb
feat: Handle database connection errors with 500 (#725)
* feat: Handle database connection errors with 500

- If database goes away while unleash is running, unleash now stays
  running, but all api endpoints will return 500.
- This includes our health endpoint, which allows k8s or similar
  orchestrators to decide what should be done, rather than Unleash
  terminating unexpectedly
2021-02-17 15:24:43 +01:00

120 lines
3.4 KiB
JavaScript

'use strict';
const test = require('ava');
const { EventEmitter } = require('events');
const eventBus = new EventEmitter();
const eventStore = new EventEmitter();
const clientMetricsStore = new EventEmitter();
const { register: prometheusRegister } = require('prom-client');
const { REQUEST_TIME, DB_TIME } = require('./events');
const { FEATURE_UPDATED } = require('./event-type');
const { createMetricsMonitor } = require('./metrics');
const monitor = createMetricsMonitor();
test.before(() => {
const featureToggleStore = {
count: async () => 123,
};
const config = {
serverMetrics: true,
eventBus,
stores: {
eventStore,
clientMetricsStore,
featureToggleStore,
db: {
client: {
pool: {
min: 0,
max: 4,
numUsed: () => 2,
numFree: () => 2,
numPendingAcquires: () => 0,
numPendingCreates: () => 1,
},
},
},
},
version: '3.4.1',
};
monitor.startMonitoring(config);
});
test.after(() => {
monitor.stopMonitoring();
});
test('should collect metrics for requests', async t => {
eventBus.emit(REQUEST_TIME, {
path: 'somePath',
method: 'GET',
statusCode: 200,
time: 1337,
});
const metrics = await prometheusRegister.metrics();
t.regex(
metrics,
/http_request_duration_milliseconds{quantile="0\.99",path="somePath",method="GET",status="200"} 1337/,
);
});
test('should collect metrics for updated toggles', async t => {
eventStore.emit(FEATURE_UPDATED, {
data: { name: 'TestToggle' },
});
const metrics = await prometheusRegister.metrics();
t.regex(metrics, /feature_toggle_update_total{toggle="TestToggle"} 1/);
});
test('should collect metrics for client metric reports', async t => {
clientMetricsStore.emit('metrics', {
bucket: {
toggles: {
TestToggle: {
yes: 10,
no: 5,
},
},
},
});
const metrics = await prometheusRegister.metrics();
t.regex(
metrics,
/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', async t => {
eventBus.emit(DB_TIME, {
store: 'foo',
action: 'bar',
time: 0.1337,
});
const metrics = await prometheusRegister.metrics();
t.regex(
metrics,
/db_query_duration_seconds{quantile="0\.99",store="foo",action="bar"} 0.1337/,
);
});
test('should collect metrics for feature toggle size', async t => {
const metrics = await prometheusRegister.metrics();
t.regex(metrics, /feature_toggles_total{version="(.*)"} 123/);
});
test('Should collect metrics for database', async t => {
const metrics = await prometheusRegister.metrics();
t.regex(metrics, /db_pool_max/);
t.regex(metrics, /db_pool_min/);
t.regex(metrics, /db_pool_used/);
t.regex(metrics, /db_pool_free/);
t.regex(metrics, /db_pool_pending_creates/);
t.regex(metrics, /db_pool_pending_acquires/);
});