summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp1
-rw-r--r--qpid/cpp/src/tests/MessagingSessionTests.cpp15
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