file_manager: fix notification sync on fast machines
Desktop class PCs may exit the request before the inotify observer gains control of the loop. When the observer does gain control it will immediately notify as the sync mutex is no longer held, this can result in sending the websocket notification before the response has returned. Delay all notifications by 5ms to prevent this. Signed-off-by: Eric Callahan <arksine.code@gmail.com>
This commit is contained in:
parent
a02209443e
commit
fce056e481
|
@ -792,7 +792,7 @@ class FileManager:
|
||||||
except Exception:
|
except Exception:
|
||||||
pass
|
pass
|
||||||
raise
|
raise
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def _parse_upload_args(self,
|
def _parse_upload_args(self,
|
||||||
upload_args: Dict[str, Any]
|
upload_args: Dict[str, Any]
|
||||||
|
@ -2144,23 +2144,19 @@ class InotifyObserver(BaseFileSystemObserver):
|
||||||
source_root, source_path)
|
source_root, source_path)
|
||||||
result['source_item'] = {'path': src_rel_path, 'root': source_root}
|
result['source_item'] = {'path': src_rel_path, 'root': source_root}
|
||||||
key = f"{action}-{root}-{rel_path}"
|
key = f"{action}-{root}-{rel_path}"
|
||||||
if sync_fut is not None:
|
self.event_loop.create_task(
|
||||||
# Delay this notification so that it occurs after an item
|
self._finish_notify(result, sync_fut, key)
|
||||||
logging.debug(f"Syncing notification: {full_path}")
|
)
|
||||||
self.event_loop.register_callback(
|
|
||||||
self._sync_with_request, result, sync_fut, key
|
|
||||||
)
|
|
||||||
else:
|
|
||||||
self.file_manager.cancel_notification(key)
|
|
||||||
self.server.send_event("file_manager:filelist_changed", result)
|
|
||||||
|
|
||||||
async def _sync_with_request(
|
async def _finish_notify(
|
||||||
self,
|
self,
|
||||||
result: Dict[str, Any],
|
result: Dict[str, Any],
|
||||||
sync_fut: asyncio.Future,
|
sync_fut: Optional[asyncio.Future],
|
||||||
notify_key: str
|
notify_key: str
|
||||||
) -> None:
|
) -> None:
|
||||||
await sync_fut
|
if sync_fut is not None:
|
||||||
|
logging.debug(f"Syncing notification: {notify_key}")
|
||||||
|
await sync_fut
|
||||||
self.file_manager.cancel_notification(notify_key)
|
self.file_manager.cancel_notification(notify_key)
|
||||||
await asyncio.sleep(.005)
|
await asyncio.sleep(.005)
|
||||||
self.server.send_event("file_manager:filelist_changed", result)
|
self.server.send_event("file_manager:filelist_changed", result)
|
||||||
|
|
Loading…
Reference in New Issue