mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-11 00:08:30 +01:00
227c6c2e7a
Currently if the intial metrics-fetch fails unleash will not setup a metrics-poller. This fix ensures that the metrics poller will start regardless of whether the inital fetch fails or succeeds. closes #396
84 lines
2.0 KiB
JavaScript
84 lines
2.0 KiB
JavaScript
'use strict';
|
|
|
|
const test = require('ava');
|
|
const ClientMetricStore = require('./client-metrics-store');
|
|
const lolex = require('lolex');
|
|
|
|
function getMockDb() {
|
|
const list = [
|
|
{ id: 4, metrics: { appName: 'test' } },
|
|
{ id: 3, metrics: { appName: 'test' } },
|
|
{ id: 2, metrics: { appName: 'test' } },
|
|
];
|
|
return {
|
|
getMetricsLastHour() {
|
|
return Promise.resolve([{ id: 1, metrics: { appName: 'test' } }]);
|
|
},
|
|
|
|
getNewMetrics() {
|
|
return Promise.resolve([list.pop() || { id: 0 }]);
|
|
},
|
|
};
|
|
}
|
|
|
|
test.cb('should call database on startup', t => {
|
|
const mock = getMockDb();
|
|
|
|
const store = new ClientMetricStore(mock);
|
|
|
|
t.plan(2);
|
|
|
|
store.on('metrics', metrics => {
|
|
t.true(store.highestIdSeen === 1);
|
|
t.true(metrics.appName === 'test');
|
|
store.destroy();
|
|
|
|
t.end();
|
|
});
|
|
});
|
|
|
|
test.cb('should start poller even if inital database fetch fails', t => {
|
|
const clock = lolex.install();
|
|
const mock = getMockDb();
|
|
mock.getMetricsLastHour = () => Promise.reject('oops');
|
|
|
|
const store = new ClientMetricStore(mock, 100);
|
|
|
|
const metrics = [];
|
|
store.on('metrics', m => metrics.push(m));
|
|
|
|
store.on('ready', () => {
|
|
t.true(metrics.length === 0);
|
|
clock.tick(300);
|
|
process.nextTick(() => {
|
|
t.true(metrics.length === 3);
|
|
t.true(store.highestIdSeen === 4);
|
|
store.destroy();
|
|
t.end();
|
|
});
|
|
});
|
|
});
|
|
|
|
test.cb('should poll for updates', t => {
|
|
const clock = lolex.install();
|
|
|
|
const mock = getMockDb();
|
|
const store = new ClientMetricStore(mock, 100);
|
|
|
|
const metrics = [];
|
|
store.on('metrics', m => metrics.push(m));
|
|
|
|
t.true(metrics.length === 0);
|
|
|
|
store.on('ready', () => {
|
|
t.true(metrics.length === 1);
|
|
clock.tick(300);
|
|
process.nextTick(() => {
|
|
t.true(metrics.length === 4);
|
|
t.true(store.highestIdSeen === 4);
|
|
store.destroy();
|
|
t.end();
|
|
});
|
|
});
|
|
});
|