2020-06-22 09:54:01 +00:00
|
|
|
const schedule = require("node-schedule");
|
|
|
|
const db = require("./db");
|
2020-08-14 15:46:38 +00:00
|
|
|
const { basicChecks } = require("./basicChecks");
|
|
|
|
const { verboseChecks } = require("./verboseChecks");
|
2020-06-22 09:54:01 +00:00
|
|
|
|
2020-08-14 15:46:38 +00:00
|
|
|
// execute the basic health-check script every 5 minutes
|
|
|
|
const basicJob = schedule.scheduleJob("*/5 * * * *", async () => {
|
2020-06-22 09:54:01 +00:00
|
|
|
const entry = { date: new Date().toISOString(), checks: [] };
|
|
|
|
|
2020-08-14 15:46:38 +00:00
|
|
|
entry.checks = await Promise.all(basicChecks.map((check) => new Promise(check)));
|
2020-06-22 09:54:01 +00:00
|
|
|
|
|
|
|
db.get("entries").push(entry).write();
|
|
|
|
});
|
|
|
|
|
2020-08-26 15:17:33 +00:00
|
|
|
// execute the verbose health-check script once per hour
|
|
|
|
const verboseJob = schedule.scheduleJob("0 * * * *", async () => {
|
2020-08-14 15:46:38 +00:00
|
|
|
const entry = { date: new Date().toISOString(), checks: [] };
|
|
|
|
|
|
|
|
entry.checks = await Promise.all(verboseChecks.map((check) => new Promise(check)));
|
|
|
|
|
|
|
|
db.get("entries").push(entry).write();
|
|
|
|
});
|
|
|
|
|
|
|
|
// Launch Health check jobs
|
2020-07-30 10:00:58 +00:00
|
|
|
setTimeout(() => {
|
2020-08-14 15:46:38 +00:00
|
|
|
basicJob.invoke();
|
|
|
|
verboseJob.invoke();
|
2020-07-30 10:00:58 +00:00
|
|
|
}, 60 * 1000); // delay for 60s to give other services time to start up
|