AMQP implementation using anyio
Project description
async_amqp
The async_amqp library is a pure-Python implementation of the AMQP 0.9.1 protocol.
Built on top of anyio, it provides an API based on coroutines, making it easy to write highly concurrent applications.
Bug reports, patches and suggestions welcome! Just open an issue or send a pull request.
Status
The code works. Porting code that uses aioamqp (or even plain python-amqp) should be reasonably straightforward.
All tests from aioamqp have been ported and succeed.
async_amqp was renamed from asyncamqp, but that was taken on pypi. asyncamqp was renamed from trio_amqp but anyio support was deemed to be a good idea. trio_amqp in turn was forked from aioamqp.
tests
To run the tests, you’ll need to install the Python test dependencies:
pip install -r ci/requirements_dev.txt
Tests require an instance of RabbitMQ. You can start a new instance using docker:
docker run -d --log-driver=syslog -e RABBITMQ_NODENAME=my-rabbit --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management
RabbitMQ requires a “guest” user (password “guest”) with admin privileges.
You can run the tests with make test (requires pytest).
tests using docker-compose
Start RabbitMQ using docker-compose up -d rabbitmq. When RabbitMQ has started, start the tests using docker-compose up --build aioamqp-test
Future work
Add coverage reporting. Increase coverage (duh).
Try restarting a failed AMQP connection instead of cancelling everything.
Project details
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 async_amqp-0.5.2-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ec05e1f81c372c9a15a28ba14124c4fe4ff3bd0728635484dc856008de2925f1 |
|
MD5 | efb4970caecf6b8e5528c040b7702e3d |
|
BLAKE2b-256 | 5dbb96faf7b7a7512cefc271fe7762b282ebfde7ee5d4a62121466d1f47a6034 |