From fe3785c9baf467c8b74f17e20769cfef30795f41 Mon Sep 17 00:00:00 2001 From: "Hiram R. Chirino" Date: Tue, 11 Jul 2006 03:55:46 +0000 Subject: [PATCH] Make the tests more reliable by explicity creating and shutting down the brokers. Also wait for the brokers to be setup before running the tests git-svn-id: https://svn.apache.org/repos/asf/incubator/activemq/branches/activemq-4.0@420697 13f79535-47bb-0310-9956-ffa450edef68 --- .../TwoBrokerTopicSendReceiveTest.java | 27 ++++++++++++++----- ...woBrokerTopicSendReceiveUsingHttpTest.java | 8 ------ ...TwoBrokerTopicSendReceiveUsingTcpTest.java | 1 - 3 files changed, 21 insertions(+), 15 deletions(-) diff --git a/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveTest.java b/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveTest.java index 9d0bca6a41..c6c165bad9 100644 --- a/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveTest.java +++ b/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveTest.java @@ -16,14 +16,17 @@ */ package org.apache.activemq.usecases; +import java.util.HashMap; +import java.util.Iterator; + import javax.jms.Connection; import javax.jms.JMSException; import org.apache.activemq.ActiveMQConnectionFactory; -import org.apache.activemq.broker.TransportConnector; import org.apache.activemq.broker.BrokerService; -import org.apache.activemq.xbean.BrokerFactoryBean; import org.apache.activemq.test.JmsTopicSendReceiveWithTwoConnectionsTest; +import org.apache.activemq.util.ServiceSupport; +import org.apache.activemq.xbean.BrokerFactoryBean; import org.springframework.core.io.ClassPathResource; /** @@ -33,10 +36,18 @@ public class TwoBrokerTopicSendReceiveTest extends JmsTopicSendReceiveWithTwoCon protected ActiveMQConnectionFactory sendFactory; protected ActiveMQConnectionFactory receiveFactory; + protected HashMap brokers = new HashMap(); protected void setUp() throws Exception { sendFactory = createSenderConnectionFactory(); receiveFactory = createReceiverConnectionFactory(); + + // Give server enough time to setup, + // so we don't lose messages when connection fails + log.info("Waiting for brokers Initialize."); + Thread.sleep(5000); + log.info("Brokers should be initialized by now.. starting test."); + super.setUp(); } @@ -50,6 +61,11 @@ public class TwoBrokerTopicSendReceiveTest extends JmsTopicSendReceiveWithTwoCon protected void tearDown() throws Exception { super.tearDown(); + for (Iterator iter = brokers.values().iterator(); iter.hasNext();) { + BrokerService broker = (BrokerService) iter.next(); + ServiceSupport.dispose(broker); + iter.remove(); + } } protected Connection createReceiveConnection() throws JMSException { @@ -64,11 +80,10 @@ public class TwoBrokerTopicSendReceiveTest extends JmsTopicSendReceiveWithTwoCon try { BrokerFactoryBean brokerFactory = new BrokerFactoryBean(new ClassPathResource(config)); brokerFactory.afterPropertiesSet(); - BrokerService broker = brokerFactory.getBroker(); - ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory(((TransportConnector)broker.getTransportConnectors().get(0)).getConnectUri()); - - return factory; + brokers.put(brokerName, broker); + + return new ActiveMQConnectionFactory(connectUrl); } catch (Exception e) { e.printStackTrace(); diff --git a/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingHttpTest.java b/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingHttpTest.java index 2f1463c168..683f831e5c 100644 --- a/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingHttpTest.java +++ b/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingHttpTest.java @@ -25,14 +25,6 @@ import javax.jms.JMSException; */ public class TwoBrokerTopicSendReceiveUsingHttpTest extends TwoBrokerTopicSendReceiveTest { - protected void setUp() throws Exception { - super.setUp(); - - // Give jetty server enough time to setup, - // so we don't lose messages when connection fails - Thread.sleep(5000); - } - protected ActiveMQConnectionFactory createReceiverConnectionFactory() throws JMSException { return createConnectionFactory("org/apache/activemq/usecases/receiver-http.xml", "receiver", "vm://receiver"); } diff --git a/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingTcpTest.java b/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingTcpTest.java index 41bbb5357e..f4bde4133e 100644 --- a/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingTcpTest.java +++ b/assembly/src/test/java/org/apache/activemq/usecases/TwoBrokerTopicSendReceiveUsingTcpTest.java @@ -46,7 +46,6 @@ public class TwoBrokerTopicSendReceiveUsingTcpTest extends TwoBrokerTopicSendRec senderBroker = brokerFactory.getBroker(); super.setUp(); - Thread.sleep(2000); } protected void tearDown() throws Exception {