goodboy
925af28092
Merge pull request #254 from goodboy/graceful_gather
...
Change to `gather_contexts()`, use event for graceful exit
2021-10-25 10:14:01 -04:00
Tyler Goodlet
d0f5c7a5e2
Change to `gather_contexts()`, use event for graceful exit
...
The api we've made here is actually closer to `asyncio.gather()` but
with opening async context managers instead of funcs. Use another event
to allow for graceful teardown of children on non-cancellation exits
and add a doc string.
2021-10-24 14:00:01 -04:00
goodboy
ebf080b8a2
Merge pull request #253 from overclockworked64/fix-type-annotation
...
Fix type annotations
2021-10-23 19:09:11 -04:00
overclockworked64
50400359b8
Fix type annotations
2021-10-24 00:47:26 +02:00
goodboy
71b8f9f1ea
Merge pull request #252 from goodboy/246_facepalm_backup
...
Trionics improvements from @overclockworked64
2021-10-23 18:10:17 -04:00
overclockworked64
b91adcf38d
Get rid of external teardown trigger
2021-10-23 16:17:30 -04:00
overclockworked64
87e3d32992
Get rid of external teardown trigger because #245 resolves the problem
2021-10-23 16:17:30 -04:00
overclockworked64
04895b9d5e
Get rid of dumb random uid and use current actor's uid
2021-10-23 16:17:30 -04:00
overclockworked64
b7a4641674
Allow specifying start_method and hard_kill
2021-10-23 16:17:30 -04:00
overclockworked64
c1089dbd95
Add a clustering test
2021-10-23 16:17:30 -04:00
overclockworked64
3130a04c61
Rename a variable and fix type annotations
2021-10-23 16:17:29 -04:00
overclockworked64
6f9229cd09
Cancel nursery
2021-10-23 16:17:29 -04:00
overclockworked64
6e6baf250b
Make sure the ID is a str
2021-10-23 16:17:29 -04:00
overclockworked64
73cbb2388a
Avoid RuntimeError by not using current_actor's uid
2021-10-23 16:17:29 -04:00
overclockworked64
2815f1c343
Make 'async_enter_all' take a teardown trigger which '_enter_and_wait' will wait on
2021-10-23 16:17:29 -04:00
overclockworked64
21afc69ac7
Postpone evaluation of annotations
2021-10-23 16:17:29 -04:00
overclockworked64
7d502cef74
Add 'open_actor_cluster' to __all__
2021-10-23 16:17:29 -04:00
overclockworked64
76767a3d7e
Add 'trio.trionics' to setup.py
2021-10-23 16:17:29 -04:00
Tyler Goodlet
c372367cc2
Fix *args-like type annot
2021-10-23 15:54:40 -04:00
Tyler Goodlet
9ddd75733c
Lul, fix everything for cluster helper
2021-10-23 15:54:40 -04:00
Tyler Goodlet
8ba10315c1
Fix type path to new `_supervise` mod
2021-10-23 15:54:40 -04:00
Tyler Goodlet
97006c904c
Expose `Lagged` for broadcasting
2021-10-23 15:54:40 -04:00
Tyler Goodlet
79fb1d0ebc
Fix top level nursery import
2021-10-23 15:54:40 -04:00
Tyler Goodlet
1e917fdb1d
Add an async actor cluster spawner prototype
2021-10-23 15:54:40 -04:00
Tyler Goodlet
4114eb1d25
Move broadcast channel parts into trionics
2021-10-23 15:54:40 -04:00
Tyler Goodlet
680a841282
Start `trionics` sub-pkg with `async_enter_all()`
...
Since it seems we're building out more and more higher level primitives
in order to support certain parallel style actor trees and messaging
patterns (eg. task broadcast channels), we might as well start a new
sub-package for purely `trio` constructions. We hereby dub this
the realm of `trionics` (like electronics but for trios instead of
electrons).
To kick things off, add an `async_enter_all()` concurrent
exit-stack-like context manager API which will concurrently spawn
a sequence of provided async context managers and deliver their ordered
results but with proper support for `trio` cancellation semantics.
The stdlib's `AsyncExitStack` is not compatible with nurseries not
`trio` tasks (which are cancelled) since as task will be suspended on
the stack after push and does not ever hit a checkpoint until the stack
is closed.
2021-10-23 15:54:40 -04:00
Tyler Goodlet
340ddba4ae
Rename the nursery module to `_supervise`
2021-10-23 15:54:40 -04:00
goodboy
be5582aae3
Merge pull request #248 from overclockworked64/patch-ci
...
Drop 3.8 support
2021-10-23 15:53:55 -04:00
overclockworked64
43cb117bf7
Add a news fragment
2021-10-23 21:52:16 +02:00
goodboy
2cf56a5f8b
Merge pull request #250 from overclockworked64/patch-dev-deps
...
Add towncrier to dev deps
2021-10-23 15:35:41 -04:00
overclockworked64
39c8447dfb
Add towncrier to dev deps
2021-10-23 20:56:18 +02:00
overclockworked64
63ddf119fd
Drop 3.8 support
2021-10-23 18:18:36 +02:00
goodboy
828754dbb5
Merge pull request #245 from goodboy/immediate_remote_cancels
...
Immediate remote cancels
2021-10-17 08:16:50 -04:00
Tyler Goodlet
b3c4851ffb
Grab lock if cancelled during spawn before hard kill
2021-10-15 18:26:46 -04:00
Tyler Goodlet
5cfac58873
Don't pop a child entry that was never inserted
2021-10-15 18:16:58 -04:00
Tyler Goodlet
5d827f78e2
Fix pluggy readme link and typo
2021-10-15 11:42:57 -04:00
Tyler Goodlet
4f222a5f9c
Use type match of expected error
2021-10-15 10:25:50 -04:00
Tyler Goodlet
e4ed0fd2b3
Right, only worry about pdb lock when in debug mode
2021-10-15 09:29:25 -04:00
Tyler Goodlet
a42ec1f571
Add nooz
2021-10-15 09:28:45 -04:00
Tyler Goodlet
533457c64d
Handle nested multierror case on windows
2021-10-15 09:16:51 -04:00
Tyler Goodlet
51259c4809
Pass uid not actor object
2021-10-14 13:46:27 -04:00
Tyler Goodlet
7ee121aeaf
Try to handle variable windows errors
2021-10-14 13:39:46 -04:00
Tyler Goodlet
9d83ef82b2
Remove union type for root getter
2021-10-14 13:39:46 -04:00
Tyler Goodlet
fa317d1600
Change lock helper to take an actor uid tuple
2021-10-14 13:39:46 -04:00
Tyler Goodlet
6f5c35dd1b
Fix missing task status type
2021-10-14 13:39:46 -04:00
Tyler Goodlet
b14699d40b
Adjust debugger tests to expect depth > 1 crashes
...
With the new fixes to the trio spawner we can expect that both root
*and* depth > 1 nursery owning actors will now not clobber any children
that are in debug (either via breakpoint or through crashing). The tests
changed now include more checks which ensure the 2nd level parent-ish
actors also bubble up through into `pdb` and don't kill any of their
(crashed) children before they're done themselves debugging.
2021-10-14 13:39:46 -04:00
Tyler Goodlet
daa28ea0e9
Handle depth > 1 nursery owners which use debug mode
2021-10-14 13:39:46 -04:00
Tyler Goodlet
4b2710b8a5
Add tty lock acquire ctx mngr
2021-10-14 13:39:46 -04:00
Tyler Goodlet
d30ce96740
Breakout `wait_for_parent_stdin_hijack()`, increase root pdb checker poll time
2021-10-14 13:39:46 -04:00
Tyler Goodlet
f3a6ab62af
Use debugger helper in nursery and spawn tasks
2021-10-14 13:39:46 -04:00