summaryrefslogtreecommitdiff
path: root/qpid/java/broker-plugins
diff options
context:
space:
mode:
authorMartin Ritchie <ritchiem@apache.org>2010-07-05 11:17:23 +0000
committerMartin Ritchie <ritchiem@apache.org>2010-07-05 11:17:23 +0000
commit039b5385d0ebd8a8571fa2443c8a8fd73f788bb2 (patch)
tree67a26ef7be0278c91acf63d1ebb116084971360a /qpid/java/broker-plugins
parent86cb7e98fcd5ebdb0f0e10e9a4efdeaf87799719 (diff)
downloadqpid-python-039b5385d0ebd8a8571fa2443c8a8fd73f788bb2.tar.gz
QPID-2681 : Add final SCD testing for Topic and Subscriptions
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@960553 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java/broker-plugins')
-rw-r--r--qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/SubscriptionTest.java146
-rw-r--r--qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/TopicTest.java85
2 files changed, 231 insertions, 0 deletions
diff --git a/qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/SubscriptionTest.java b/qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/SubscriptionTest.java
new file mode 100644
index 0000000000..9e9375fd44
--- /dev/null
+++ b/qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/SubscriptionTest.java
@@ -0,0 +1,146 @@
+/*
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ *
+ */
+package org.apache.qpid.systest;
+
+import org.apache.commons.configuration.ConfigurationException;
+
+import javax.jms.Session;
+import javax.naming.NamingException;
+import java.io.IOException;
+
+/**
+ * Test SCD when configured with Subscription details.
+ *
+ * We run the subscription based tests here to validate that the
+ * subscriptionname value is correctly associated with the subscription.
+ *
+ *
+ */
+public class SubscriptionTest extends TestingBaseCase
+{
+ private int _count=0;
+ protected String CONFIG_SECTION = ".topics.topic";
+
+ /**
+ * Add configuration for the queue that relates just to this test.
+ * We use the getTestQueueName() as our subscription. To ensure the
+ * config sections do not overlap we identify each section with a _count
+ * value.
+ *
+ * This would allow each test to configure more than one section.
+ *
+ * @param property to set
+ * @param value the value to set
+ * @param deleteDurable should deleteDurable be set.
+ * @throws NamingException
+ * @throws IOException
+ * @throws ConfigurationException
+ */
+ public void setConfig(String property, String value, boolean deleteDurable) throws NamingException, IOException, ConfigurationException
+ {
+ setProperty(CONFIG_SECTION + "("+_count+").subscriptionName", "clientid:"+getTestQueueName());
+
+ setProperty(CONFIG_SECTION + "("+_count+").slow-consumer-detection." +
+ "policy.name", "TopicDelete");
+
+ setProperty(CONFIG_SECTION + "("+_count+").slow-consumer-detection." +
+ property, value);
+
+ if (deleteDurable)
+ {
+ setProperty(CONFIG_SECTION + "("+_count+").slow-consumer-detection." +
+ "policy.topicdelete.delete-persistent", "");
+ }
+ _count++;
+ }
+
+
+ /**
+ * Test that setting messageCount takes affect on a durable Consumer
+ *
+ * Ensure we set the delete-persistent option
+ *
+ * We send 10 messages and disconnect at 9
+ *
+ * @throws Exception
+ */
+
+ public void testTopicDurableConsumerMessageCount() throws Exception
+ {
+ MAX_QUEUE_MESSAGE_COUNT = 10;
+
+ setConfig("messageCount", String.valueOf(MAX_QUEUE_MESSAGE_COUNT - 1), true);
+
+ //Start the broker
+ startBroker();
+
+ topicConsumer(Session.AUTO_ACKNOWLEDGE, true);
+ }
+
+ /**
+ * Test that setting depth has an effect on durable consumer topics
+ *
+ * Ensure we set the delete-persistent option
+ *
+ * Sets the message size for the test
+ * Sets the depth to be 9 * the depth
+ * Ensure that sending 10 messages causes the disconnection
+ *
+ * @throws Exception
+ */
+ public void testTopicDurableConsumerMessageSize() throws Exception
+ {
+ MAX_QUEUE_MESSAGE_COUNT = 10;
+
+ setConfig("depth", String.valueOf(MESSAGE_SIZE * 9), true);
+
+ //Start the broker
+ startBroker();
+
+ setMessageSize(MESSAGE_SIZE);
+
+ topicConsumer(Session.AUTO_ACKNOWLEDGE, true);
+ }
+
+ /**
+ * Test that setting messageAge has an effect on topics
+ *
+ * Ensure we set the delete-persistent option
+ *
+ * Sets the messageAge to be 1/5 the disconnection wait timeout (or 1sec)
+ * Send 10 messages and then ensure that we get disconnected as we will
+ * wait for the full timeout.
+ *
+ * @throws Exception
+ */
+ public void testTopicDurableConsumerMessageAge() throws Exception
+ {
+ MAX_QUEUE_MESSAGE_COUNT = 10;
+
+ setConfig("messageAge", String.valueOf(DISCONNECTION_WAIT / 5), true);
+
+ //Start the broker
+ startBroker();
+
+ topicConsumer(Session.AUTO_ACKNOWLEDGE, true);
+ }
+
+}
diff --git a/qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/TopicTest.java b/qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/TopicTest.java
new file mode 100644
index 0000000000..09c849cfde
--- /dev/null
+++ b/qpid/java/broker-plugins/experimental/slowconsumerdetection/src/test/java/org/apache/qpid/systest/TopicTest.java
@@ -0,0 +1,85 @@
+/*
+ *
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you under the Apache License, Version 2.0 (the
+ * "License"); you may not use this file except in compliance
+ * with the License. You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing,
+ * software distributed under the License is distributed on an
+ * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+ * KIND, either express or implied. See the License for the
+ * specific language governing permissions and limitations
+ * under the License.
+ *
+ */
+package org.apache.qpid.systest;
+
+import org.apache.commons.configuration.ConfigurationException;
+
+import javax.naming.NamingException;
+import java.io.IOException;
+
+/**
+ * This Topic test extends the Global queue test so it will run all the topic
+ * and subscription tests.
+ *
+ * We redefine the CONFIG_SECTION here so that the configuration is written
+ * against a topic element.
+ *
+ * To complete the migration to testing 'topic' elements we also override
+ * the setConfig to use the test name as the topic name.
+ *
+ */
+public class TopicTest extends GlobalQueuesTest
+{
+ private int _count=0;
+
+ @Override
+ public void setUp() throws Exception
+ {
+ CONFIG_SECTION = ".topics.topic";
+ super.setUp();
+ }
+
+ /**
+ * Add configuration for the queue that relates just to this test.
+ * We use the getTestQueueName() as our subscription. To ensure the
+ * config sections do not overlap we identify each section with a _count
+ * value.
+ *
+ * This would allow each test to configure more than one section.
+ *
+ * @param property to set
+ * @param value the value to set
+ * @param deleteDurable should deleteDurable be set.
+ * @throws NamingException
+ * @throws IOException
+ * @throws ConfigurationException
+ */
+ @Override
+ public void setConfig(String property, String value, boolean deleteDurable) throws NamingException, IOException, ConfigurationException
+ {
+ setProperty(CONFIG_SECTION + "("+_count+").name", getName());
+
+ setProperty(CONFIG_SECTION + "("+_count+").slow-consumer-detection." +
+ "policy.name", "TopicDelete");
+
+ setProperty(CONFIG_SECTION + "("+_count+").slow-consumer-detection." +
+ property, value);
+
+ if (deleteDurable)
+ {
+ setProperty(CONFIG_SECTION + "("+_count+").slow-consumer-detection." +
+ "policy.topicdelete.delete-persistent", "");
+ }
+ _count++;
+ }
+
+
+}