.. towncrier release notes start
- ptaskgroup: Implement
PersistentTaskGroup
(#30) - server: Expose
process_index
context variable for worker processes (#31)
- Add support for Python 3.10. (#28)
- Fix documentation builds on Python 3.10 and Sphinx 4.x, by removing the 3rd-party autodoc-typehints extension and custom stylesheet overrides. (#28)
- fork: Handle children's segfault (core-dump with signals) explicitly in
PidfdChildProcess
(#27)
- Avoid side effects of custom
clone()
function and resorts back to the combinatino ofos.fork()
andos.pidfd_open()
for now (#25)
- server: The
use_threading
argument forstart_server()
is completely deprecated. (#23)
- Now the primary target is Python 3.9, though we still support from Python 3.6 (#22)
- fork: Add a new module
fork
to support PID file descriptors in Linux 5.4+ and a POSIX-compatible fallback to asynchornously fork the Python process without signal/PID races. (#22) - server: Completely rewrote the module using the new
fork
module with handling of various edge cases such as async failures of sibiling child processes (#23)
- Fix a potential memory leak with
TaskGroup
when it's used for long-lived asyncio tasks. (#21)
- Add a
current_taskgroup
context-variable to the taskgroup module (only available for Python 3.7 or later)
- Fix missing auto-import of
taskgroup
module exports in theaiotools
root package.
- Adopt an implementation of the taskgroup API as
aiotools.taskgroup
from EdgeDB (#18) - Add
timer.VirtualClock
which provides a virtual clock that makes a block of asyncio codes usingasyncio.sleep()
to complete instantly and deterministically (#19)
- A maintenance release to fix up the
defer
module exports in theaiotools
namespace.
- defer: A new module that emulates Golang's
defer()
API with asyncio awareness.
- server: Rewrite internals of the worker main functions to use native
async with
instead of manually unrolling__aenter__()
and__aexit__()
dunder methods, to keep the code simple and avoid potential bugs.
- Python 3.8 is now officially supported.
- server: Fix errors when
multiprocessing.set_start_method("spawn")
is used.- NOTE: This is now the default for macOS since Python 3.8.
- KNOWN ISSUE: #12
- Remove some packaging hacks in
__init__.py
and let setuptools read the version from a separateaiotools/VERSION
text file.
- context: Fix
aclosing()
's__aexit__()
exception arguments.
- context, server: Catch asyncio.CancelledError along with BaseException to make the cancellation behavior consistent in Python 3.6, 3.7, and 3.8.
- server: Fix yields of the received stop signal in main/worker context managers when using threaded workers.
- server: Updated stop signal handling and now user-defined worker/main context managers have a way to distinguish the stop signal received. See the updated docs for more details.
- This ia a technical release to fix a test case preventing the automated CI release procedure.
- Improve support for Python 3.6/3.7 using a small compatibility module against asyncio.
- func: Add
expire_after
option tolru_cache()
function.
- Minor updates to the documentation
- Add support for Python 3.7
- context: Updated to work like Python 3.7
- context: Deprecated
AsyncContextDecorator
stuffs in Python 3.7+ - context: Added an alias to
contextlib.AsyncExitStack
in the standard library.
- Introduce a new module
aiotools.iter
withaiter()
function which corresponds to an async version of the builtiniter()
.
- server: Remove use of unncessary setpgrp syscall, which is also blocked by Docker's default seccomp profile!
- server: Ooops! (a finally block should have been an else block)
- server: Improve inner beauty (code readability)
- server: Improve reliability and portability of worker-to-main interrupts
- server: Fix a race condition related to handling of worker initialization errors with multiple workers
- func: Add
lru_cache()
which is a coroutine version offunctools.lru_cache()
- server: Fix a race condition related to signal handling in the multiprocessing module during termination
- server: Improve error handling during initialization of workers (automatic shutdown of other workers and the main loop after logging the exception)
- Add a new module
aiotools.func
withapartial()
function which is an async version offunctools.partial()
in the standard library
- Add
aclosing()
context manager likeclosing()
in the standard library - Speed up Travis CI builds for packaging
- Now provide README in rst as well as CHANGES (this file)
server
: Fix spawning subprocesses in child workers- Add support for
uvloop
- Add
use_threading
argument to - Add initial documentation (which currently not served on readthedocs.io due to Python version problem)
- Add
extra_procs
argument tostart_server()
function - Add socket and ZeroMQ server examples
- Improve CI configs
- Improve CI scripts
- Adopt editorconfig
- Add
start_server()
function using multiprocessing with automatic children lifecycle management - Clarify the semantics of
AsyncContextGroup
usingasyncio.gather()
withreturn_exceptions=True
- Add abstract types for
AsyncContextManager
- Rename
AsyncGenContextManager
toAsyncContextManager
- Add
AsyncContextGroup
- Initial release