diff options
author | Gordon Sim <gsim@apache.org> | 2014-08-14 17:04:25 +0000 |
---|---|---|
committer | Gordon Sim <gsim@apache.org> | 2014-08-14 17:04:25 +0000 |
commit | 74f06cdc3206bd6504a07ae12fc24c7408c2da57 (patch) | |
tree | 9fd1fd55f2d8f0b37ff0adf78db90dfa4ea0ae7f | |
parent | d31375772e29ad3c45e44e99a2e88762d245ae1f (diff) | |
download | qpid-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.cpp | 3 | ||||
-rw-r--r-- | qpid/cpp/src/tests/MessagingSessionTests.cpp | 40 |
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 |