diff options
author | Ted Ross <tross@apache.org> | 2012-06-13 20:32:36 +0000 |
---|---|---|
committer | Ted Ross <tross@apache.org> | 2012-06-13 20:32:36 +0000 |
commit | 391274867fbacd85a76a9dc654d6e398eb6422f1 (patch) | |
tree | 3de6abff41049bce873a1749bfa85193e7e2ac42 | |
parent | c20a9a0f572b31fe6de26d607efeb523493a5b90 (diff) | |
download | qpid-python-391274867fbacd85a76a9dc654d6e398eb6422f1.tar.gz |
QPID-4065 - Remove the message's trace list during Queue::reRoute
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1350003 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | qpid/cpp/src/qpid/broker/Message.cpp | 12 | ||||
-rw-r--r-- | qpid/cpp/src/qpid/broker/Message.h | 1 | ||||
-rw-r--r-- | qpid/cpp/src/qpid/broker/Queue.cpp | 1 | ||||
-rw-r--r-- | qpid/tests/src/py/qpid_tests/broker_0_10/management.py | 13 |
4 files changed, 26 insertions, 1 deletions
diff --git a/qpid/cpp/src/qpid/broker/Message.cpp b/qpid/cpp/src/qpid/broker/Message.cpp index 40dfba39f4..4dd8a349dd 100644 --- a/qpid/cpp/src/qpid/broker/Message.cpp +++ b/qpid/cpp/src/qpid/broker/Message.cpp @@ -384,6 +384,18 @@ void Message::addTraceId(const std::string& id) } } +void Message::clearTrace() +{ + sys::Mutex::ScopedLock l(lock); + if (isA<MessageTransferBody>()) { + FieldTable& headers = getModifiableProperties<MessageProperties>()->getApplicationHeaders(); + std::string trace = headers.getAsString(X_QPID_TRACE); + if (!trace.empty()) { + headers.setString(X_QPID_TRACE, ""); + } + } +} + void Message::setTimestamp() { sys::Mutex::ScopedLock l(lock); diff --git a/qpid/cpp/src/qpid/broker/Message.h b/qpid/cpp/src/qpid/broker/Message.h index dda45d73e6..90e4eec889 100644 --- a/qpid/cpp/src/qpid/broker/Message.h +++ b/qpid/cpp/src/qpid/broker/Message.h @@ -161,6 +161,7 @@ public: bool isExcluded(const std::vector<std::string>& excludes) const; void addTraceId(const std::string& id); + void clearTrace(); void forcePersistent(); bool isForcedPersistent(); diff --git a/qpid/cpp/src/qpid/broker/Queue.cpp b/qpid/cpp/src/qpid/broker/Queue.cpp index 0dff832475..f3f206d571 100644 --- a/qpid/cpp/src/qpid/broker/Queue.cpp +++ b/qpid/cpp/src/qpid/broker/Queue.cpp @@ -809,6 +809,7 @@ uint32_t Queue::purge(const uint32_t purge_request, boost::shared_ptr<Exchange> // now reroute if necessary if (dest.get()) { assert(qmsg->payload); + qmsg->payload->clearTrace(); DeliverableMessage dmsg(qmsg->payload); dest->routeWithAlternate(dmsg); } diff --git a/qpid/tests/src/py/qpid_tests/broker_0_10/management.py b/qpid/tests/src/py/qpid_tests/broker_0_10/management.py index 2dd2291b2e..a1316ea854 100644 --- a/qpid/tests/src/py/qpid_tests/broker_0_10/management.py +++ b/qpid/tests/src/py/qpid_tests/broker_0_10/management.py @@ -302,9 +302,10 @@ class ManagementTest (TestBase010): twenty = range(1,21) props = session.delivery_properties(routing_key="routing_key") + mp = session.message_properties(application_headers={'x-qpid.trace' : 'A,B,C'}) for count in twenty: body = "Reroute Message %d" % count - msg = Message(props, body) + msg = Message(props, mp, body) session.message_transfer(destination="amq.direct", message=msg) pq = self.qmf.getObjects(_class="queue", name="reroute-queue")[0] @@ -317,6 +318,16 @@ class ManagementTest (TestBase010): self.assertEqual(pq.msgDepth,19) self.assertEqual(aq.msgDepth,1) + "Verify that the trace was cleared on the rerouted message" + url = "%s://%s:%d" % (self.broker.scheme or "amqp", self.broker.host, self.broker.port) + conn = qpid.messaging.Connection(url) + conn.open() + sess = conn.session() + rx = sess.receiver("alt-queue1;{mode:browse}") + rm = rx.fetch(1) + self.assertEqual(rm.properties['x-qpid.trace'], '') + conn.close() + "Reroute top 9 messages from reroute-queue to alt.direct2" result = pq.reroute(9, False, "alt.direct2", {}) self.assertEqual(result.status, 0) |