update_manager: fix potential race condition with auto_refresh
Wait until update manager init is complete before attempting starting the auto refresh periodic callback. This prevents an auto refresh from blocking init if Moonraker is started during the auto refresh window. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
7f740ccb5a
commit
0d1431395e
|
@ -142,7 +142,6 @@ class UpdateManager:
|
||||||
self.refresh_cb = PeriodicCallback(
|
self.refresh_cb = PeriodicCallback(
|
||||||
self._handle_auto_refresh, # type: ignore
|
self._handle_auto_refresh, # type: ignore
|
||||||
UPDATE_REFRESH_INTERVAL_MS)
|
UPDATE_REFRESH_INTERVAL_MS)
|
||||||
self.refresh_cb.start()
|
|
||||||
|
|
||||||
self.server.register_endpoint(
|
self.server.register_endpoint(
|
||||||
"/machine/update/moonraker", ["POST"],
|
"/machine/update/moonraker", ["POST"],
|
||||||
|
@ -187,6 +186,8 @@ class UpdateManager:
|
||||||
ret = updater.refresh()
|
ret = updater.refresh()
|
||||||
await ret
|
await ret
|
||||||
self.initialized_lock.set()
|
self.initialized_lock.set()
|
||||||
|
if self.refresh_cb is not None:
|
||||||
|
self.refresh_cb.start()
|
||||||
|
|
||||||
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:
|
||||||
|
|
Loading…
Reference in New Issue