2016-11-06 20:52:08 +01:00
|
|
|
'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'));
|
2016-11-07 08:44:46 +01:00
|
|
|
list.add({ n: '2' }, moment().add(50, 'milliseconds'));
|
|
|
|
list.add({ n: '3' }, moment().add(200, 'milliseconds'));
|
|
|
|
list.add({ n: '4' }, moment().add(300, 'milliseconds'));
|
2016-11-06 20:52:08 +01:00
|
|
|
|
|
|
|
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);
|
|
|
|
});
|