summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGordon Sim <gsim@apache.org>2014-08-14 17:04:25 +0000
committerGordon Sim <gsim@apache.org>2014-08-14 17:04:25 +0000
commit74f06cdc3206bd6504a07ae12fc24c7408c2da57 (patch)
tree9fd1fd55f2d8f0b37ff0adf78db90dfa4ea0ae7f
parentd31375772e29ad3c45e44e99a2e88762d245ae1f (diff)
downloadqpid-python-74f06cdc3206bd6504a07ae12fc24c7408c2da57.tar.gz
QPID-5985: check for messages on nextReceiver(IMMEDIATE); merged two commits from trunk (r1617256,1617924)
git-svn-id: https://svn.apache.org/repos/asf/qpid/branches/0.30@1617992 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp3
-rw-r--r--qpid/cpp/src/tests/MessagingSessionTests.cpp40
2 files changed, 42 insertions, 1 deletions
diff --git a/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp b/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp
index 5d8a77999e..6d62c44be8 100644
--- a/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp
+++ b/qpid/cpp/src/qpid/client/amqp0_10/IncomingMessages.cpp
@@ -175,7 +175,7 @@ bool IncomingMessages::getNextDestination(std::string& destination, qpid::sys::D
{
sys::Mutex::ScopedLock l(lock);
AbsTime deadline(AbsTime::now(), timeout);
- while (received.empty() && AbsTime::now() < deadline) {
+ while (received.empty()) {
if (inUse) {
//someone is already waiting on the sessions incoming queue
lock.wait(deadline);
@@ -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 95b985b5ae..d01dd69999 100644
--- a/qpid/cpp/src/tests/MessagingSessionTests.cpp
+++ b/qpid/cpp/src/tests/MessagingSessionTests.cpp
@@ -1450,6 +1450,46 @@ QPID_AUTO_TEST_CASE(testSessionCheckError)
}
}
+QPID_AUTO_TEST_CASE(testImmediateNextReceiver)
+{
+ QueueFixture fix;
+ Sender sender = fix.session.createSender(fix.queue);
+ Message out("test message");
+ sender.send(out);
+ fix.session.createReceiver(fix.queue).setCapacity(1);
+ Receiver next;
+ qpid::sys::AbsTime start = qpid::sys::now();
+ try {
+ while (!fix.session.nextReceiver(next, qpid::messaging::Duration::IMMEDIATE)) {
+ qpid::sys::Duration running(start, qpid::sys::now());
+ 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));
+ BOOST_CHECK_EQUAL(in.getContent(), out.getContent());
+ next.close();
+ } catch (const std::exception& e) {
+ BOOST_FAIL(e.what());
+ }
+}
+
+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