tractor/tractor
Tyler Goodlet ddbda17338 Solve our abandonment issues..
To make the recent set of tests pass this (hopefully) finally solves all
`asyncio` embedded `trio` guest-run abandonment by ensuring we "pump the
event loop" until the guest-run future is fully complete.

Accomplished via simple poll loop of the form `while not
trio_done_fut.done(): await asyncio.sleep(.1)` in the `aio_main()`
task's exception teardown sequence. The loop does a naive 10ms
"pump-via-sleep & poll" for the `trio` side to complete before finally
exiting (and presumably raising) from the SIGINT cancellation.

Other related cleanups and refinements:
- use `asyncio.Task.result()` inside `cancel_trio()` since it also
  inline-raises any exception outcome and we can also log-report the
  result in non-error cases.
- comment out buncha not-sure-we-need-it stuff in `cancel_trio()`.
- remove the botched `AsyncioCancelled(CancelledError):` idea obvi XD
- comment `greenback` init for now in `aio_main()` since (pretty sure)
  we don't ever want to actually REPL in that specific func-as-task?
- always capture any `fute_err: BaseException` from the `main_outcome:
  Outcome` delivered by the `trio` side guest-run task.
- add and raise a new super noisy `AsyncioRuntimeTranslationError`
  whenever we detect that the guest-run `trio_done_fut` has not
  completed before task exit; should avoid abandonment issues ever
  happening again without knowing!
2025-03-22 14:20:39 -04:00
..
_testing Start a new `._testing.fault_simulation` 2025-03-21 15:25:41 -04:00
devx Further formalize `greenback` integration 2025-03-21 15:25:55 -04:00
experimental Drop now-deprecated deps on modern `trio`/Python 2025-03-16 16:06:24 -04:00
msg Report any external-rent-task-canceller during msg-drain 2025-03-21 15:25:55 -04:00
trionics Refine some `.trionics` docs and logging 2025-03-21 15:25:55 -04:00
__init__.py Finally implement peer-lookup optimization.. 2025-03-21 15:25:55 -04:00
_child.py Hide `._entry`/`._child` frames, tweak some more type annots 2025-03-20 23:22:45 -04:00
_clustering.py Passthrough runtime kwargs from `open_actor_cluster()` 2022-12-11 19:56:08 -05:00
_context.py Add `indent: str` suport to `Context.pformat()` using `textwrap` 2025-03-21 15:25:55 -04:00
_discovery.py Finally implement peer-lookup optimization.. 2025-03-21 15:25:55 -04:00
_entry.py More-n-more scops annots in logging 2025-03-21 15:25:55 -04:00
_exceptions.py Lel, revert `AsyncioCancelled` inherit, module.. 2025-03-22 14:20:38 -04:00
_forkserver_override.py Re-license code base for distribution under AGPL 2021-12-14 23:33:27 -05:00
_ipc.py More formal `TransportClosed` reporting/raising 2025-03-21 15:25:55 -04:00
_mp_fixup_main.py Avoid importing mp for as long as possible 2022-02-17 11:55:26 -05:00
_multiaddr.py Fix doc string "its" typo.. 2025-03-20 19:50:31 -04:00
_portal.py More-n-more scops annots in logging 2025-03-21 15:25:55 -04:00
_root.py Further formalize `greenback` integration 2025-03-21 15:25:55 -04:00
_rpc.py More formal `TransportClosed` reporting/raising 2025-03-21 15:25:55 -04:00
_runtime.py Denoise duplicate chan logging for now 2025-03-21 15:25:55 -04:00
_spawn.py Use `._entry` proto-ed "lifetime ops" in logging 2025-03-21 15:25:55 -04:00
_state.py Further formalize `greenback` integration 2025-03-21 15:25:55 -04:00
_streaming.py Reraise RAEs in `MsgStream.receive()`; truncate tbs 2025-03-21 15:25:55 -04:00
_supervise.py Add `tb_hide: bool` ctl flag to `_open_and_supervise_one_cancels_all_nursery()` 2025-03-21 15:25:55 -04:00
log.py Woops, set `.cancel()` level in custom levels table.. 2025-03-21 15:25:55 -04:00
to_asyncio.py Solve our abandonment issues.. 2025-03-22 14:20:39 -04:00