summaryrefslogtreecommitdiff
path: root/qpid/java/broker/src/main
diff options
context:
space:
mode:
authorMartin Ritchie <ritchiem@apache.org>2010-07-05 11:16:17 +0000
committerMartin Ritchie <ritchiem@apache.org>2010-07-05 11:16:17 +0000
commit89a83eed58fcbbf07e5f85c3dee15e70a734131a (patch)
tree8850f20d626c865e09d206f6df0ee314f8cc7269 /qpid/java/broker/src/main
parentfe0a8104595f24fc392254b1d0f9962a22d31e87 (diff)
downloadqpid-python-89a83eed58fcbbf07e5f85c3dee15e70a734131a.tar.gz
QPID-2681 : Correcly process global configuration, added test to cover
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@960549 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java/broker/src/main')
-rw-r--r--qpid/java/broker/src/main/java/org/apache/qpid/server/configuration/TopicConfiguration.java15
1 files changed, 12 insertions, 3 deletions
diff --git a/qpid/java/broker/src/main/java/org/apache/qpid/server/configuration/TopicConfiguration.java b/qpid/java/broker/src/main/java/org/apache/qpid/server/configuration/TopicConfiguration.java
index a16198788f..c7a195f9e4 100644
--- a/qpid/java/broker/src/main/java/org/apache/qpid/server/configuration/TopicConfiguration.java
+++ b/qpid/java/broker/src/main/java/org/apache/qpid/server/configuration/TopicConfiguration.java
@@ -77,8 +77,6 @@ public class TopicConfiguration extends ConfigurationPlugin implements ExchangeC
for (int index = 0; index < topics; index++)
{
- TopicConfig topic = new TopicConfig();
-
Configuration topicSubset = _configuration.subset("topic(" + index + ")");
// This will occur when we have a subscriptionName that is bound to a
@@ -88,6 +86,8 @@ public class TopicConfiguration extends ConfigurationPlugin implements ExchangeC
break;
}
+ TopicConfig topic = new TopicConfig();
+
topic.setConfiguration(VIRTUALHOSTS_VIRTUALHOST_TOPICS + ".topic", topicSubset );
String name = _configuration.getString("topic(" + index + ").name");
@@ -169,6 +169,7 @@ public class TopicConfiguration extends ConfigurationPlugin implements ExchangeC
*/
public ConfigurationPlugin getConfiguration(AMQQueue queue)
{
+ //Create config with global topic configuration
TopicConfig config = new TopicConfig();
// Add global topic configuration
@@ -225,7 +226,15 @@ public class TopicConfiguration extends ConfigurationPlugin implements ExchangeC
}
}
- // Apply subscription specfic config.
+ //todo we don't account for wild cards here. only explict matching and all subscriptions
+ if (subscriptionSpecificConfig == null)
+ {
+ // lookup the binding to see if we have a match in the subscription configs
+ subscriptionSpecificConfig = topics.get("#");
+ }
+
+
+ // Apply subscription specific config.
if (subscriptionSpecificConfig != null)
{
config.addConfiguration(subscriptionSpecificConfig);