tractor/examples/remote_error_propagation.py

31 lines
731 B
Python
Raw Normal View History

2021-02-24 18:39:14 +00:00
import trio
import tractor
async def assert_err():
assert 0
async def main():
async with tractor.open_nursery() as n:
real_actors = []
for i in range(3):
real_actors.append(await n.start_actor(
f'actor_{i}',
2021-02-24 23:46:33 +00:00
enable_modules=[__name__],
))
# start one actor that will fail immediately
await n.run_in_actor(assert_err)
# should error here with a ``RemoteActorError`` containing
# an ``AssertionError`` and all the other actors have been cancelled
if __name__ == '__main__':
try:
# also raises
2021-02-24 18:39:14 +00:00
trio.run(main)
except tractor.RemoteActorError:
print("Look Maa that actor failed hard, hehhh!")