smarttime/test/test.cronmanager.ts

50 lines
1.5 KiB
TypeScript
Raw Normal View History

2019-04-10 09:34:30 +00:00
import { tap, expect } from '@pushrocks/tapbundle';
import * as smarttime from '../ts/index';
let testCronManager: smarttime.CronManager;
tap.test('should create a valid instance of cronmanager', async () => {
testCronManager = new smarttime.CronManager();
2019-04-10 12:06:20 +00:00
expect(testCronManager).to.be.instanceOf(smarttime.CronManager);
});
2020-07-11 21:41:33 +00:00
tap.test('should create a valid cronJon', async (tools) => {
2019-04-10 12:06:20 +00:00
const done = tools.defer();
2020-09-03 20:06:02 +00:00
const done2 = tools.defer();
const done3 = tools.defer();
2019-04-10 12:06:20 +00:00
let counter = 0;
2020-09-03 20:06:02 +00:00
let counter2 = 0;
let counter3 = 0;
const cronJob = testCronManager.addCronjob('*/2 * * * * *', async () => {
2019-06-17 14:54:39 +00:00
if (counter === 10) {
2020-09-03 20:06:02 +00:00
testCronManager.removeCronjob(cronJob);
2019-04-10 12:06:20 +00:00
done.resolve();
}
2019-06-17 14:54:39 +00:00
counter++;
2020-09-03 20:06:02 +00:00
console.log(`${new Date().getSeconds()} hey ${counter} -> runs every 2 seconds`);
});
const cronJob2 = testCronManager.addCronjob('*/3 * * * * *', async () => {
if (counter2 === 10) {
testCronManager.removeCronjob(cronJob2);
done2.resolve();
}
counter2++;
console.log(`${new Date().getSeconds()} hey ${counter2} -> runs every 3 seconds`);
});
const cronJob3 = testCronManager.addCronjob('*/4 * * * * *', async () => {
if (counter3 === 10) {
done3.resolve();
}
counter3++;
console.log(`${new Date().getSeconds()} hey ${counter3} -> runs every 4 seconds`);
2019-04-10 12:06:20 +00:00
});
testCronManager.start();
await done.promise;
2020-09-03 20:06:02 +00:00
await done2.promise;
await done3.promise;
2019-04-10 12:06:20 +00:00
testCronManager.stop();
2019-04-10 09:34:30 +00:00
});
tap.start();