1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/packages/unleash-api/lib/client-metrics/ttl-list.test.js
2020-02-20 08:30:36 +01:00

61 lines
1.4 KiB
JavaScript

'use strict';
const test = require('ava');
const TTLList = require('./ttl-list');
const moment = require('moment');
test.cb('should emit expire', (t) => {
const list = new TTLList({
interval: 20,
expireAmount: 10,
expireType: 'milliseconds',
});
list.on('expire', (entry) => {
list.destroy();
t.true(entry.n === 1);
t.end();
});
list.add({ n: 1 });
});
test.cb('should slice off list', (t) => {
const list = new TTLList({
interval: 10,
expireAmount: 10,
expireType: 'milliseconds',
});
// console.time('4');
// console.time('3');
// console.time('2');
// console.time('1');
list.add({ n: '1' }, moment().add(1, 'milliseconds'));
list.add({ n: '2' }, moment().add(50, 'milliseconds'));
list.add({ n: '3' }, moment().add(200, 'milliseconds'));
list.add({ n: '4' }, moment().add(300, 'milliseconds'));
const expired = [];
list.on('expire', (entry) => {
// console.timeEnd(entry.n);
expired.push(entry);
});
setTimeout(() => {
t.true(expired.length === 1);
}, 30);
setTimeout(() => {
t.true(expired.length === 2);
}, 71);
setTimeout(() => {
t.true(expired.length === 3);
}, 221);
setTimeout(() => {
t.true(expired.length === 4);
list.destroy();
t.end();
}, 330);
});