diff --git a/src/consumer.cc b/src/consumer.cc index 67d2daa..346673a 100644 --- a/src/consumer.cc +++ b/src/consumer.cc @@ -64,7 +64,8 @@ void Consumer_negative_acknowledge(Consumer& consumer, const Message& msg) { } void Consumer_negative_acknowledge_message_id(Consumer& consumer, const MessageId& msgId) { - waitForAsyncResult([&](ResultCallback callback) { consumer.acknowledgeAsync(msgId, callback); }); + Py_BEGIN_ALLOW_THREADS consumer.negativeAcknowledge(msgId); + Py_END_ALLOW_THREADS } void Consumer_acknowledge_cumulative(Consumer& consumer, const Message& msg) { diff --git a/tests/pulsar_test.py b/tests/pulsar_test.py index 839ec3e..1872e0f 100755 --- a/tests/pulsar_test.py +++ b/tests/pulsar_test.py @@ -286,7 +286,10 @@ def test_redelivery_count(self): for i in range(4): msg = consumer.receive(TM) print("Received message %s" % msg.data()) - consumer.negative_acknowledge(msg) + if i % 2 == 0: + consumer.negative_acknowledge(msg) + else: + consumer.negative_acknowledge(msg.message_id()) redelivery_count = msg.redelivery_count() self.assertTrue(msg)