summaryrefslogtreecommitdiff
path: root/qpid/java/systests/src/main/java/org/apache/qpid/systest/SubscriptionTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'qpid/java/systests/src/main/java/org/apache/qpid/systest/SubscriptionTest.java')
-rw-r--r--qpid/java/systests/src/main/java/org/apache/qpid/systest/SubscriptionTest.java146
1 files changed, 146 insertions, 0 deletions
diff --git a/qpid/java/systests/src/main/java/org/apache/qpid/systest/SubscriptionTest.java b/qpid/java/systests/src/main/java/org/apache/qpid/systest/SubscriptionTest.java
new file mode 100644
index 0000000000..9e9375fd44
--- /dev/null
+++ b/qpid/java/systests/src/main/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);
+ }
+
+}