diff options
author | Maxim Devaev <[email protected]> | 2022-08-05 15:07:17 +0300 |
---|---|---|
committer | Maxim Devaev <[email protected]> | 2022-08-05 15:07:17 +0300 |
commit | eeaeebf7c76385536eb8f5daaea5f21bda18b735 (patch) | |
tree | 5c8008edd4e4fea85da5e7e16f32389ede95f56a /kvmd/plugins/msd/otg | |
parent | 9ee63aba3ead6493acd01c89ffe17c503cdb4017 (diff) |
shield some finally ops
Diffstat (limited to 'kvmd/plugins/msd/otg')
-rw-r--r-- | kvmd/plugins/msd/otg/__init__.py | 32 |
1 files changed, 26 insertions, 6 deletions
diff --git a/kvmd/plugins/msd/otg/__init__.py b/kvmd/plugins/msd/otg/__init__.py index 96ef9289..2d556048 100644 --- a/kvmd/plugins/msd/otg/__init__.py +++ b/kvmd/plugins/msd/otg/__init__.py @@ -354,9 +354,17 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes yield self.__reader finally: - await self.__close_reader() + # FIXME: Перехват важен потому что по какой-то причине await + # во вложенных finally путаются и выполняются не по порядку + try: + await asyncio.shield(self.__close_reader()) + except asyncio.CancelledError: + pass finally: - await self.__notifier.notify() + try: + await asyncio.shield(self.__notifier.notify()) + except asyncio.CancelledError: + pass @contextlib.asynccontextmanager async def write_image(self, name: str, size: int, remove_incomplete: Optional[bool]) -> AsyncGenerator[MsdFileWriter, None]: @@ -398,13 +406,25 @@ class Plugin(BaseMsd): # pylint: disable=too-many-instance-attributes os.remove(path) except Exception: pass - await self.__close_writer() - await self.__remount_rw(False, fatal=False) + try: + await asyncio.shield(self.__close_writer()) + except asyncio.CancelledError: + pass + try: + await asyncio.shield(self.__remount_rw(False, fatal=False)) + except asyncio.CancelledError: + pass finally: # Между закрытием файла и эвентом айнотифи состояние может быть не обновлено, # так что форсим обновление вручную, чтобы получить актуальное состояние. - await self.__reload_state() - await self.__notifier.notify() + try: + await asyncio.shield(self.__reload_state()) + except asyncio.CancelledError: + pass + try: + await asyncio.shield(self.__notifier.notify()) + except asyncio.CancelledError: + pass @aiotools.atomic async def remove(self, name: str) -> None: |