|
9 | 9 | ConnectionClosed, |
10 | 10 | Environment, |
11 | 11 | ExchangeSpecification, |
| 12 | + OutcomeState, |
12 | 13 | QuorumQueueSpecification, |
13 | 14 | StreamSpecification, |
14 | 15 | ) |
15 | 16 |
|
16 | 17 | from .http_requests import delete_all_connections |
| 18 | +from .utils import publish_per_message |
17 | 19 |
|
18 | 20 |
|
19 | 21 | def test_publish_queue(connection: Connection) -> None: |
@@ -46,6 +48,48 @@ def test_publish_queue(connection: Connection) -> None: |
46 | 48 | assert raised is False |
47 | 49 |
|
48 | 50 |
|
| 51 | +def test_publish_per_message(connection: Connection) -> None: |
| 52 | + |
| 53 | + queue_name = "test-queue-1" |
| 54 | + queue_name_2 = "test-queue-2" |
| 55 | + management = connection.management() |
| 56 | + |
| 57 | + management.declare_queue(QuorumQueueSpecification(name=queue_name)) |
| 58 | + management.declare_queue(QuorumQueueSpecification(name=queue_name_2)) |
| 59 | + |
| 60 | + raised = False |
| 61 | + |
| 62 | + publisher = None |
| 63 | + accepted = False |
| 64 | + accepted_2 = True |
| 65 | + |
| 66 | + try: |
| 67 | + publisher = connection.publisher() |
| 68 | + status = publish_per_message(publisher, queue_name) |
| 69 | + if status.remote_state == OutcomeState.ACCEPTED: |
| 70 | + accepted = True |
| 71 | + status = publish_per_message(publisher, queue_name_2) |
| 72 | + if status.remote_state == OutcomeState.ACCEPTED: |
| 73 | + accepted_2 = True |
| 74 | + except Exception: |
| 75 | + raised = True |
| 76 | + |
| 77 | + if publisher is not None: |
| 78 | + publisher.close() |
| 79 | + |
| 80 | + purged_messages_queue_1 = management.purge_queue(queue_name) |
| 81 | + purged_messages_queue_2 = management.purge_queue(queue_name_2) |
| 82 | + management.delete_queue(queue_name) |
| 83 | + management.delete_queue(queue_name_2) |
| 84 | + management.close() |
| 85 | + |
| 86 | + assert accepted is True |
| 87 | + assert accepted_2 is True |
| 88 | + assert purged_messages_queue_1 == 1 |
| 89 | + assert purged_messages_queue_2 == 1 |
| 90 | + assert raised is False |
| 91 | + |
| 92 | + |
49 | 93 | def test_publish_ssl(connection_ssl: Connection) -> None: |
50 | 94 |
|
51 | 95 | queue_name = "test-queue" |
|
0 commit comments