/* * JBoss, Home of Professional Open Source * Copyright 2005-2008, Red Hat Middleware LLC, and individual contributors * by the @authors tag. See the copyright.txt in the distribution for a * full listing of individual contributors. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.jboss.test.messaging.jms.bridge; import java.util.Properties; import org.jboss.messaging.core.logging.Logger; import org.jboss.test.messaging.tools.ServerManagement; /** * @author <a href="mailto:tim.fox@jboss.com">Tim Fox</a> * @version <tt>$Revision: 1.1 $</tt> * * $Id$ * */ public class ReconnectWithRecoveryTest extends BridgeTestBase { private static final Logger log = Logger.getLogger(ReconnectTest.class); public ReconnectWithRecoveryTest(String name) { super(name); } protected void setUp() throws Exception { super.setUp(); //Now install local JMSProviderAdaptor classes Properties props1 = new Properties(); props1.putAll(ServerManagement.getJNDIEnvironment(1)); /*JMSProviderAdapter targetAdaptor = new TestJMSProviderAdaptor(props1, "/XAConnectionFactory", "adaptor1"); sc.installJMSProviderAdaptor("adaptor1", targetAdaptor); sc.startRecoveryManager();*/ } protected void tearDown() throws Exception { super.tearDown(); /*sc.stopRecoveryManager(); sc.uninstallJMSProviderAdaptor("adaptor1");*/ log.debug(this + " torn down"); } public void testNoop() { } /* * TODO: What to do with this test? * Send some messages * Crash the server after prepare but on commit * Bring up the destination server * Send some more messages * Verify all messages are received */ // public void testCrashAndReconnectDestCrashOnCommit() throws Exception // { // Bridge bridge = null; // // try // { // final int NUM_MESSAGES = 10; // // bridge = new Bridge(cff0, cff1, sourceQueueFactory, targetQueueFactory, // null, null, null, null, // null, 1000, -1, Bridge.QOS_ONCE_AND_ONLY_ONCE, // NUM_MESSAGES, -1, // null, null, false); // // bridge.start(); // // //Poison server 1 so it crashes on commit of dest but after prepare // // //This means the transaction branch on source will get commmitted // //but the branch on dest won't be - it will remain prepared // //This corresponds to a HeuristicMixedException // // ServerManagement.poisonTheServer(1, PoisonInterceptor.TYPE_2PC_COMMIT); // // log.info("Poisoned server"); // // //Send some messages // // sendMessages(cf0, sourceQueue, 0, NUM_MESSAGES, true); // // //Restart the server // // //Wait a bit for the batch to be sent - this should cause the server to crash on commit // // Thread.sleep(3000); // // log.info("Restarting server"); // // ServerManagement.start(1, "all", false); // // log.info("Restarted server"); // // deployQueue("targetQueue", 1); // // this.setUpAdministeredObjects(); // // log.info("Deployed queue"); // // log.info("*** waiting for recovery"); // // //There may be a long wait for the first time (need to let recovery kick in) // checkMessagesReceived(cf1, targetQueue, Bridge.QOS_ONCE_AND_ONLY_ONCE, NUM_MESSAGES, true); // } // finally // { // if (bridge != null) // { // try // { // bridge.stop(); // } // catch (Exception e) // { // log.error("Failed to stop bridge", e); // } // } // } // } // Inner classes ------------------------------------------------------------------- }