diff options
| author | Ted Ross <tross@apache.org> | 2012-02-15 21:58:46 +0000 |
|---|---|---|
| committer | Ted Ross <tross@apache.org> | 2012-02-15 21:58:46 +0000 |
| commit | 37d762898624deb99809d609084dc0bbd20dce3a (patch) | |
| tree | 62ffd27a064540d376b989b6954e2ecb8cd33e0a | |
| parent | 35d7a77569c9b28b1b1692e244c60f8a0ed46356 (diff) | |
| download | qpid-python-37d762898624deb99809d609084dc0bbd20dce3a.tar.gz | |
QPID-3847 - Fixed recursive ID generation when V1 and V2 are mixed.
Thanks to Siddhesh Poyarekar for his help with this issue.
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@1244750 13f79535-47bb-0310-9956-ffa450edef68
| -rwxr-xr-x | qpid/tools/src/py/qpid-tool | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/qpid/tools/src/py/qpid-tool b/qpid/tools/src/py/qpid-tool index df8b7e3f96..af948b13a9 100755 --- a/qpid/tools/src/py/qpid-tool +++ b/qpid/tools/src/py/qpid-tool @@ -252,6 +252,20 @@ class QmfData(Console): elif tokens[0].isdigit(): self.showObjectById(int(tokens[0])) + def _build_object_name(self, obj): + values = [] + for p,v in obj.getProperties(): + if p.name != "vhostRef" and p.index == 1: + if p.name == "brokerRef": # reference to broker + values.append('org.apache.qpid.broker:broker:amqp-broker') + else: + values.append(str(v)) + + object_key = ",".join(values) + class_key = obj.getClassKey(); + return class_key.getPackageName() + ":" + class_key.getClassName() + ":" + object_key + + def do_call(self, data): tokens = data.split() if len(tokens) < 2: @@ -290,10 +304,8 @@ class QmfData(Console): object_id = obj.getObjectId(); if not object_id.isV2 and obj.getAgent().isV2: - object_key = ",".join([str(v) for p, v in obj.getProperties() if p.name != "vhostRef" and p.index == 1]) - class_key = obj.getClassKey(); - object_name = class_key.getPackageName() + ":" + class_key.getClassName() + ":" + object_key - object_id = ObjectId.create(object_id.agentName, object_name) + object_name = self._build_object_name(obj) + object_id = ObjectId.create(object_id.agentName, object_name) self.session._sendMethodRequest(self.broker, obj.getClassKey(), object_id, methodName, args) |
