update_manager: auto-refresh fix

Only refresh a provider when the update interval has expired.

Signed-off-by:  Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
Eric Callahan 2021-12-09 16:35:43 -05:00
parent 56a98aa8ed
commit 08111415be
1 changed files with 11 additions and 7 deletions

View File

@ -180,7 +180,7 @@ class UpdateManager:
ret = updater.refresh() ret = updater.refresh()
await ret await ret
if self.refresh_timer is not None: if self.refresh_timer is not None:
self.refresh_timer.start() self.refresh_timer.start(delay=UPDATE_REFRESH_INTERVAL)
async def _set_klipper_repo(self) -> None: async def _set_klipper_repo(self) -> None:
if self.klippy_identified_evt is not None: if self.klippy_identified_evt is not None:
@ -225,7 +225,7 @@ class UpdateManager:
return pstate.lower() == "printing" return pstate.lower() == "printing"
async def _handle_auto_refresh(self, eventtime: float) -> float: async def _handle_auto_refresh(self, eventtime: float) -> float:
cur_hour = time.localtime(eventtime).tm_hour cur_hour = time.localtime(time.time()).tm_hour
# Update when the local time is between 12AM and 5AM # Update when the local time is between 12AM and 5AM
if cur_hour >= MAX_UPDATE_HOUR: if cur_hour >= MAX_UPDATE_HOUR:
return eventtime + UPDATE_REFRESH_INTERVAL return eventtime + UPDATE_REFRESH_INTERVAL
@ -234,14 +234,18 @@ class UpdateManager:
logging.info("Klippy is printing, auto refresh aborted") logging.info("Klippy is printing, auto refresh aborted")
return eventtime + UPDATE_REFRESH_INTERVAL return eventtime + UPDATE_REFRESH_INTERVAL
vinfo: Dict[str, Any] = {} vinfo: Dict[str, Any] = {}
need_notify = False
async with self.cmd_request_lock: async with self.cmd_request_lock:
try: try:
for name, updater in list(self.updaters.items()): for name, updater in list(self.updaters.items()):
if updater.needs_refresh():
await updater.refresh() await updater.refresh()
need_notify = True
vinfo[name] = updater.get_update_status() vinfo[name] = updater.get_update_status()
except Exception: except Exception:
logging.exception("Unable to Refresh Status") logging.exception("Unable to Refresh Status")
return eventtime + UPDATE_REFRESH_INTERVAL return eventtime + UPDATE_REFRESH_INTERVAL
if need_notify:
uinfo = self.cmd_helper.get_rate_limit_stats() uinfo = self.cmd_helper.get_rate_limit_stats()
uinfo['version_info'] = vinfo uinfo['version_info'] = vinfo
uinfo['busy'] = self.cmd_helper.is_update_busy() uinfo['busy'] = self.cmd_helper.is_update_busy()