diff options
-rw-r--r-- | qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp | 1 | ||||
-rw-r--r-- | qpid/cpp/src/tests/MessagingSessionTests.cpp | 15 |
2 files changed, 16 insertions, 0 deletions
diff --git a/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp b/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp index 4080efc340..6d62c44be8 100644 --- a/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp +++ b/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp @@ -186,6 +186,7 @@ bool IncomingMessages::getNextDestination(std::string& destination, qpid::sys::D //wait for an incoming message wait(timeout == qpid::sys::TIME_INFINITE ? qpid::sys::TIME_INFINITE : qpid::sys::Duration(AbsTime::now(), deadline)); } + if (!(AbsTime::now() < deadline)) break; } if (!received.empty()) { destination = received.front()->as<MessageTransferBody>()->getDestination(); diff --git a/qpid/cpp/src/tests/MessagingSessionTests.cpp b/qpid/cpp/src/tests/MessagingSessionTests.cpp index 0859bae619..d01dd69999 100644 --- a/qpid/cpp/src/tests/MessagingSessionTests.cpp +++ b/qpid/cpp/src/tests/MessagingSessionTests.cpp @@ -1465,6 +1465,7 @@ QPID_AUTO_TEST_CASE(testImmediateNextReceiver) if (running > 5*qpid::sys::TIME_SEC) { throw qpid::types::Exception("Timed out spinning on nextReceiver(IMMEDIATE)"); } + qpid::sys::usleep(1); // for valgrind } Message in; BOOST_CHECK(next.fetch(in, qpid::messaging::Duration::IMMEDIATE)); @@ -1475,6 +1476,20 @@ QPID_AUTO_TEST_CASE(testImmediateNextReceiver) } } +QPID_AUTO_TEST_CASE(testImmediateNextReceiverNoMessage) +{ + QueueFixture fix; + Receiver r = fix.session.createReceiver(fix.queue); + r.setCapacity(1); + Receiver next; + try { + BOOST_CHECK(!fix.session.nextReceiver(next, qpid::messaging::Duration::IMMEDIATE)); + r.close(); + } catch (const std::exception& e) { + BOOST_FAIL(e.what()); + } +} + QPID_AUTO_TEST_SUITE_END() }} // namespace qpid::tests |