fix(core): update

This commit is contained in:
Philipp Kunz 2020-09-04 06:39:22 +00:00
parent a7a961c869
commit 457182a97a
2 changed files with 19 additions and 9 deletions

View File

@ -21,18 +21,29 @@ export class CronJob {
*/ */
public checkExecution(): number { public checkExecution(): number {
if (this.nextExecutionUnix === 0) { if (this.nextExecutionUnix === 0) {
this.nextExecutionUnix = Date.now() + this.croner.msToNext(); this.getNextExecutionTime();
} }
if (Date.now() > this.nextExecutionUnix) { if (Date.now() > this.nextExecutionUnix) {
const maybePromise = this.jobFunction(); const maybePromise = this.jobFunction();
if (maybePromise instanceof Promise) { if (maybePromise instanceof Promise) {
maybePromise.catch(e => console.log(e)); maybePromise.catch(e => console.log(e));
} }
this.nextExecutionUnix = Date.now() + this.croner.msToNext(); this.nextExecutionUnix = this.getNextExecutionTime();
} }
return this.nextExecutionUnix; return this.nextExecutionUnix;
} }
public getNextExecutionTime() {
return this.nextExecutionUnix = Date.now() + this.getTimeToNextExecution();
}
/**
* gets the time to next execution
*/
public getTimeToNextExecution() {
return this.croner.msToNext();
}
public start() { public start() {
this.status = 'started'; this.status = 'started';
} }

View File

@ -36,18 +36,17 @@ export class CronManager {
const runCronCycle = async () => { const runCronCycle = async () => {
this.executionTimeout = new plugins.smartdelay.Timeout(0); this.executionTimeout = new plugins.smartdelay.Timeout(0);
do { do {
let timeToNextOverallExecution: number; let nextRunningCronjob: CronJob;
for (const cronJob of this.cronjobs.getArray()) { for (const cronJob of this.cronjobs.getArray()) {
const nextExecutionTime = cronJob.checkExecution(); cronJob.checkExecution();
const timeToNextJobExecution = nextExecutionTime - Date.now();
if ( if (
timeToNextJobExecution < timeToNextOverallExecution || !nextRunningCronjob ||
!timeToNextOverallExecution cronJob.getTimeToNextExecution() < nextRunningCronjob.getTimeToNextExecution()
) { ) {
timeToNextOverallExecution = timeToNextJobExecution; nextRunningCronjob = cronJob;
} }
} }
this.executionTimeout = new plugins.smartdelay.Timeout(timeToNextOverallExecution); this.executionTimeout = new plugins.smartdelay.Timeout(nextRunningCronjob.getTimeToNextExecution());
console.log( console.log(
`Next CronJob scheduled in ${this.executionTimeout.getTimeLeft()} milliseconds` `Next CronJob scheduled in ${this.executionTimeout.getTimeLeft()} milliseconds`
); );