'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);
});