mirror of
https://github.com/Unleash/unleash.git
synced 2025-01-20 00:08:02 +01:00
feat: add ids to scheduled jobs (#4764)
* Adds an ID to scheduled jobs so that they are easier to identify in the future
This commit is contained in:
parent
2c55e929ae
commit
a71c3fe43a
@ -93,16 +93,19 @@ export const scheduleServices = async (
|
||||
schedulerService.schedule(
|
||||
apiTokenService.fetchActiveTokens.bind(apiTokenService),
|
||||
minutesToMilliseconds(1),
|
||||
'fetchActiveTokens',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
apiTokenService.updateLastSeen.bind(apiTokenService),
|
||||
minutesToMilliseconds(3),
|
||||
'updateLastSeen',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
instanceStatsService.refreshStatsSnapshot.bind(instanceStatsService),
|
||||
minutesToMilliseconds(5),
|
||||
'refreshStatsSnapshot',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
@ -110,16 +113,19 @@ export const scheduleServices = async (
|
||||
clientInstanceService,
|
||||
),
|
||||
hoursToMilliseconds(24),
|
||||
'removeInstancesOlderThanTwoDays',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
projectService.statusJob.bind(projectService),
|
||||
hoursToMilliseconds(24),
|
||||
'statusJob',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
projectHealthService.setHealthRating.bind(projectHealthService),
|
||||
hoursToMilliseconds(1),
|
||||
'setHealthRating',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
@ -127,6 +133,7 @@ export const scheduleServices = async (
|
||||
configurationRevisionService,
|
||||
),
|
||||
secondsToMilliseconds(1),
|
||||
'updateMaxRevisionId',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
@ -134,6 +141,7 @@ export const scheduleServices = async (
|
||||
eventAnnouncerService,
|
||||
),
|
||||
secondsToMilliseconds(1),
|
||||
'publishUnannouncedEvents',
|
||||
);
|
||||
|
||||
schedulerService.schedule(
|
||||
@ -141,6 +149,7 @@ export const scheduleServices = async (
|
||||
featureToggleService,
|
||||
),
|
||||
minutesToMilliseconds(1),
|
||||
'updatePotentiallyStaleFeatures',
|
||||
);
|
||||
};
|
||||
|
||||
|
@ -26,7 +26,7 @@ test('Schedules job immediately', async () => {
|
||||
const schedulerService = new SchedulerService(logger);
|
||||
const job = jest.fn();
|
||||
|
||||
schedulerService.schedule(job, 10);
|
||||
schedulerService.schedule(job, 10, 'test-id');
|
||||
|
||||
expect(job).toBeCalledTimes(1);
|
||||
schedulerService.stop();
|
||||
@ -38,7 +38,7 @@ test('Does not schedule job immediately when paused', async () => {
|
||||
const job = jest.fn();
|
||||
|
||||
schedulerService.pause();
|
||||
schedulerService.schedule(job, 10);
|
||||
schedulerService.schedule(job, 10, 'test-id-2');
|
||||
|
||||
expect(job).toBeCalledTimes(0);
|
||||
schedulerService.stop();
|
||||
@ -49,7 +49,7 @@ test('Can schedule a single regular job', async () => {
|
||||
const schedulerService = new SchedulerService(logger);
|
||||
const job = jest.fn();
|
||||
|
||||
schedulerService.schedule(job, 50);
|
||||
schedulerService.schedule(job, 50, 'test-id-3');
|
||||
await ms(75);
|
||||
|
||||
expect(job).toBeCalledTimes(2);
|
||||
@ -62,7 +62,7 @@ test('Scheduled job ignored in a paused mode', async () => {
|
||||
const job = jest.fn();
|
||||
|
||||
schedulerService.pause();
|
||||
schedulerService.schedule(job, 50);
|
||||
schedulerService.schedule(job, 50, 'test-id-4');
|
||||
await ms(75);
|
||||
|
||||
expect(job).toBeCalledTimes(0);
|
||||
@ -75,7 +75,7 @@ test('Can resume paused job', async () => {
|
||||
const job = jest.fn();
|
||||
|
||||
schedulerService.pause();
|
||||
schedulerService.schedule(job, 50);
|
||||
schedulerService.schedule(job, 50, 'test-id-5');
|
||||
schedulerService.resume();
|
||||
await ms(75);
|
||||
|
||||
@ -89,8 +89,8 @@ test('Can schedule multiple jobs at the same interval', async () => {
|
||||
const job = jest.fn();
|
||||
const anotherJob = jest.fn();
|
||||
|
||||
schedulerService.schedule(job, 50);
|
||||
schedulerService.schedule(anotherJob, 50);
|
||||
schedulerService.schedule(job, 50, 'test-id-6');
|
||||
schedulerService.schedule(anotherJob, 50, 'test-id-7');
|
||||
await ms(75);
|
||||
|
||||
expect(job).toBeCalledTimes(2);
|
||||
@ -104,8 +104,8 @@ test('Can schedule multiple jobs at the different intervals', async () => {
|
||||
const job = jest.fn();
|
||||
const anotherJob = jest.fn();
|
||||
|
||||
schedulerService.schedule(job, 100);
|
||||
schedulerService.schedule(anotherJob, 200);
|
||||
schedulerService.schedule(job, 100, 'test-id-8');
|
||||
schedulerService.schedule(anotherJob, 200, 'test-id-9');
|
||||
await ms(250);
|
||||
|
||||
expect(job).toBeCalledTimes(3);
|
||||
@ -120,13 +120,13 @@ test('Can handle crash of a async job', async () => {
|
||||
await Promise.reject('async reason');
|
||||
};
|
||||
|
||||
schedulerService.schedule(job, 50);
|
||||
schedulerService.schedule(job, 50, 'test-id-10');
|
||||
await ms(75);
|
||||
|
||||
schedulerService.stop();
|
||||
expect(getRecords()).toEqual([
|
||||
['scheduled job failed', 'async reason'],
|
||||
['scheduled job failed', 'async reason'],
|
||||
['scheduled job failed | id: test-id-10 | async reason'],
|
||||
['scheduled job failed | id: test-id-10 | async reason'],
|
||||
]);
|
||||
});
|
||||
|
||||
@ -137,12 +137,12 @@ test('Can handle crash of a sync job', async () => {
|
||||
throw new Error('sync reason');
|
||||
};
|
||||
|
||||
schedulerService.schedule(job, 50);
|
||||
schedulerService.schedule(job, 50, 'test-id-11');
|
||||
await ms(75);
|
||||
|
||||
schedulerService.stop();
|
||||
expect(getRecords()).toEqual([
|
||||
['scheduled job failed', new Error('sync reason')],
|
||||
['scheduled job failed', new Error('sync reason')],
|
||||
['scheduled job failed | id: test-id-11 | Error: sync reason'],
|
||||
['scheduled job failed | id: test-id-11 | Error: sync reason'],
|
||||
]);
|
||||
});
|
||||
|
@ -17,6 +17,7 @@ export class SchedulerService {
|
||||
async schedule(
|
||||
scheduledFunction: () => void,
|
||||
timeMs: number,
|
||||
id: string,
|
||||
): Promise<void> {
|
||||
this.intervalIds.push(
|
||||
setInterval(async () => {
|
||||
@ -25,7 +26,9 @@ export class SchedulerService {
|
||||
await scheduledFunction();
|
||||
}
|
||||
} catch (e) {
|
||||
this.logger.error('scheduled job failed', e);
|
||||
this.logger.error(
|
||||
`scheduled job failed | id: ${id} | ${e}`,
|
||||
);
|
||||
}
|
||||
}, timeMs).unref(),
|
||||
);
|
||||
@ -34,7 +37,7 @@ export class SchedulerService {
|
||||
await scheduledFunction();
|
||||
}
|
||||
} catch (e) {
|
||||
this.logger.error('scheduled job failed', e);
|
||||
this.logger.error(`scheduled job failed | id: ${id} | ${e}`);
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user