asyncio-run-in-process: Asyncio friendly replacement for multiprocessing
Project description
asyncio-run-in-process
Simple asyncio friendly replacement for multiprocessing
Read more in the documentation on ReadTheDocs. View the change log.
Quickstart
pip install asyncio-run-in-process
Developer Setup
If you would like to hack on asyncio-run-in-process, please check out the Snake Charmers Tactical Manual for information on how we do:
- Testing
- Pull Requests
- Code Style
- Documentation
Development Environment Setup
You can set up your dev environment with:
git clone git@github.com:ethereum/asyncio-run-in-process.git
cd asyncio-run-in-process
virtualenv -p python3 venv
. venv/bin/activate
pip install -e .[dev]
Testing Setup
During development, you might like to have tests run on every file save.
Show flake8 errors on file change:
# Test flake8
when-changed -v -s -r -1 asyncio_run_in_process/ tests/ -c "clear; flake8 asyncio_run_in_process tests && echo 'flake8 success' || echo 'error'"
Run multi-process tests in one command, but without color:
# in the project root:
pytest --numprocesses=4 --looponfail --maxfail=1
# the same thing, succinctly:
pytest -n 4 -f --maxfail=1
Run in one thread, with color and desktop notifications:
cd venv
ptw --onfail "notify-send -t 5000 'Test failure ⚠⚠⚠⚠⚠' 'python 3 test on asyncio-run-in-process failed'" ../tests ../asyncio_run_in_process
Release setup
For Debian-like systems:
apt install pandoc
To release a new version:
make release bump=$$VERSION_PART_TO_BUMP$$
How to bumpversion
The version format for this repo is {major}.{minor}.{patch}
for stable, and
{major}.{minor}.{patch}-{stage}.{devnum}
for unstable (stage
can be alpha or beta).
To issue the next version in line, specify which part to bump,
like make release bump=minor
or make release bump=devnum
. This is typically done from the
master branch, except when releasing a beta (in which case the beta is released from master,
and the previous stable branch is released from said branch). To include changes made with each
release, update "docs/releases.rst" with the changes, and apply commit directly to master
before release.
If you are in a beta version, make release bump=stage
will switch to a stable.
To issue an unstable version when the current version is stable, specify the
new version explicitly, like make release bump="--new-version 4.0.0-alpha.1 devnum"
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for asyncio-run-in-process-0.1.0a10.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 84f50d46569e383041371f723d3cebb19a9ebad2a0aaaa663526871b2b38bbc9 |
|
MD5 | 218061d252484352b9ae00d0831fbc29 |
|
BLAKE2b-256 | eba57a3651a6690ffda5f7dc4dec88b37a01acbd0dc2d54c6d173005a9b5a1a4 |
Hashes for asyncio_run_in_process-0.1.0a10-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | c15c9f7dcedc8811743eb6e4a520b132b9a3e74c8b40f23e4cbbd89af3b34670 |
|
MD5 | cf6a68306d77f64d518aef6209a2433f |
|
BLAKE2b-256 | 280c7d0b450c2783cdf112e215a84546b2be43170582fbfc90c192c64d7e97e9 |