Merge pull request #1936 from balena-os/sleep-between-reports

Use delay instead of interval to recursively report state
This commit is contained in:
bulldozer-balena[bot] 2022-04-28 18:26:43 +00:00 committed by GitHub
commit 01934503e5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,5 +1,6 @@
import * as url from 'url'; import * as url from 'url';
import * as _ from 'lodash'; import * as _ from 'lodash';
import { delay } from 'bluebird';
import { CoreOptions } from 'request'; import { CoreOptions } from 'request';
import * as constants from '../lib/constants'; import * as constants from '../lib/constants';
@ -141,15 +142,24 @@ export async function startReporting() {
); );
const doReport = async () => { const doReport = async () => {
if (!reportPending) { if (!reportPending) {
throttledReport(reportConfigs); await throttledReport(reportConfigs);
} }
}; };
// If the state changes, report it // If the state changes, report it
deviceState.on('change', doReport); deviceState.on('change', doReport);
// But check once every max report frequency to ensure that changes in system
// info are picked up (CPU temp etc) async function recursivelyReport(delayBy: number) {
setInterval(doReport, constants.maxReportFrequency); try {
// Try to perform a report right away // Try to send current state
return doReport(); await doReport();
} finally {
// Wait until we want to report again
await delay(delayBy);
// Try to report again
await recursivelyReport(delayBy);
}
}
return recursivelyReport(constants.maxReportFrequency);
} }