Skip to content

Commit

Permalink
docs: ability to declare queue/exchange binding (airtai#2011)
Browse files Browse the repository at this point in the history
* feat: declare queue/exchange binding

* docs: generate API References

* docs: reverting the changes and adding queue/exchange binding to the documentation

* docs: reverting the changes and adding queue/exchange binding to the documentation

* docs: reverting the changes and adding queue/exchange binding to the documentation

* docs: generate API References

* test: added some testing for the doc code snippet

* chore: polish docs

* tests: fix RMQ bind test

---------

Co-authored-by: MagicAbdel <[email protected]>
Co-authored-by: Nikita Pastukhov <[email protected]>
  • Loading branch information
3 people authored Dec 30, 2024
1 parent 9603989 commit 4a5c491
Show file tree
Hide file tree
Showing 3 changed files with 78 additions and 0 deletions.
11 changes: 11 additions & 0 deletions docs/docs/en/rabbit/declare.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ search:

# RabbitMQ Queue/Exchange Declaration

## Declaring queues and exchanges

**FastStream** *subscribers* declares and validates all using *RabbitMQ* exchanges and queues (*publishers* declares exchanges only), but sometimes you need to declare them manually.

**RabbitBroker** provides a way to achieve this easily.
Expand All @@ -22,3 +24,12 @@ These methods require just one argument (`RabbitQueue`/`RabbitExchange`) contain

!!! tip
Also, these methods are idempotent, so you can call them with the same arguments multiple times, but the objects will be created once; next time the method will return an already stored object. This way you can get access to any queue/exchange created automatically.


## Binding a queue to an exchange

It is also possible to bind a queue and an exchange using low-level **aio-pika** `RobustQueue.bind` method:

```python linenums="1" hl_lines="24-26 28-30 32-35"
{! docs_src/rabbit/bind.py !}
```
37 changes: 37 additions & 0 deletions docs/docs_src/rabbit/bind.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import aio_pika
from faststream import FastStream
from faststream.rabbit import (
ExchangeType,
RabbitBroker,
RabbitExchange,
RabbitQueue,
)

broker = RabbitBroker()
app = FastStream(broker)


some_queue = RabbitQueue(
name="some-queue",
durable=True,
)

some_exchange = RabbitExchange(
name="some-exchange",
type=ExchangeType.FANOUT,
)

@app.after_startup
async def bind_queue_exchange():
queue: aio_pika.RobustQueue = await broker.declare_queue(
some_queue
)

exchange: aio_pika.RobustExchange = await broker.declare_exchange(
some_exchange
)

await queue.bind(
exchange=exchange,
routing_key=queue.name # Optional parameter
)
30 changes: 30 additions & 0 deletions tests/a_docs/rabbit/test_bind.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
from unittest.mock import AsyncMock

import pytest
from aio_pika import RobustQueue

from faststream import TestApp
from tests.marks import require_aiopika


@pytest.mark.asyncio
@pytest.mark.rabbit
@require_aiopika
async def test_bind(monkeypatch, async_mock: AsyncMock):
from docs.docs_src.rabbit.bind import app, broker, some_exchange, some_queue

with monkeypatch.context() as m:
m.setattr(RobustQueue, "bind", async_mock)

async with TestApp(app):
assert len(broker.declarer._RabbitDeclarer__queues) == 2 # with `reply-to`
assert len(broker.declarer._RabbitDeclarer__exchanges) == 1

assert some_queue in broker.declarer._RabbitDeclarer__queues
assert some_exchange in broker.declarer._RabbitDeclarer__exchanges

row_exchange = await broker.declarer.declare_exchange(some_exchange)
async_mock.assert_awaited_once_with(
exchange=row_exchange,
routing_key=some_queue.name,
)

0 comments on commit 4a5c491

Please sign in to comment.