Package org.hornetq.tests.integration.management

Source Code of org.hornetq.tests.integration.management.ManagementActivationTest

/*
* Copyright 2010 Red Hat, Inc.
* Red Hat 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.hornetq.tests.integration.management;

import org.hornetq.api.core.TransportConfiguration;
import org.hornetq.jms.server.config.ConnectionFactoryConfiguration;
import org.hornetq.jms.server.config.impl.ConnectionFactoryConfigurationImpl;
import org.hornetq.jms.server.impl.JMSServerManagerImpl;
import org.hornetq.tests.integration.cluster.failover.FailoverTestBase;
import org.hornetq.tests.unit.util.InVMContext;
import org.hornetq.tests.util.TransportConfigurationUtils;

import javax.jms.ConnectionFactory;
import javax.jms.Queue;
import javax.jms.Topic;
import javax.naming.NameNotFoundException;
import java.util.ArrayList;
import java.util.List;

/**
* Validates if a JMS management operations will wait until the server is activated.  If the server is not active
* then JMS management operations (e.g. create connection factory, create queue, etc.) should be stored in a cache
* and then executed once the server becomes active.  The normal use-case for this involves a live/backup pair.
*
* @author clebertsuconic
* @author Justin Bertram
*/
public class ManagementActivationTest extends FailoverTestBase
{
   private JMSServerManagerImpl backupJmsServer;
   private InVMContext context;
   private String connectorName;

   @Override
   protected TransportConfiguration getAcceptorTransportConfiguration(boolean live)
   {
      return TransportConfigurationUtils.getInVMAcceptor(live);
   }

   @Override
   protected TransportConfiguration getConnectorTransportConfiguration(boolean live)
   {
      TransportConfiguration inVMConnector = TransportConfigurationUtils.getInVMConnector(live);
      connectorName = inVMConnector.getName();
      return inVMConnector;
   }

   @Override
   protected void setUp() throws Exception
   {
      super.setUp();
      backupJmsServer = new JMSServerManagerImpl(backupServer.getServer());
      context = new InVMContext();
      backupJmsServer.setContext(context);
      backupJmsServer.start();
   }

   public void testCreateConnectionFactory() throws Exception
   {
      List<String> connectorNames = new ArrayList<String>();
      connectorNames.add(connectorName);

      ConnectionFactoryConfiguration config =  new ConnectionFactoryConfigurationImpl("test", false, connectorNames, "/myConnectionFactory");
      backupJmsServer.createConnectionFactory(true, config, "/myConnectionFactory");

      boolean exception = false;
      try
      {
         context.lookup("/myConnectionFactory");
      }
      catch (NameNotFoundException e)
      {
         exception = true;
      }

      assertTrue("exception expected", exception);

      liveServer.crash();

      long timeout = System.currentTimeMillis() + 5000;

      ConnectionFactory factory = null;
      while (timeout > System.currentTimeMillis())
      {
         try
         {
            factory = (ConnectionFactory) context.lookup("/myConnectionFactory");
         }
         catch (Exception ignored)
         {
            // ignored.printStackTrace();
         }
         if (factory == null)
         {
            Thread.sleep(100);
         }
         else
         {
            break;
         }
      }

      assertNotNull(factory);
   }

   public void testCreateQueue() throws Exception
   {
      backupJmsServer.createQueue(false, "myQueue", null, false, "/myQueue");

      boolean exception = false;
      try
      {
         context.lookup("/myQueue");
      }
      catch (NameNotFoundException e)
      {
         exception = true;
      }

      assertTrue("exception expected", exception);

      liveServer.crash();

      long timeout = System.currentTimeMillis() + 5000;

      Queue queue = null;
      while (timeout > System.currentTimeMillis())
      {
         try
         {
            queue = (Queue) context.lookup("/myQueue");
         }
         catch (Exception ignored)
         {
            // ignored.printStackTrace();
         }
         if (queue == null)
         {
            Thread.sleep(100);
         }
         else
         {
            break;
         }
      }

      assertNotNull(queue);
   }

   public void testCreateTopic() throws Exception
   {
      backupJmsServer.createTopic(false, "myTopic", "/myTopic");

      boolean exception = false;
      try
      {
         context.lookup("/myTopic");
      }
      catch (NameNotFoundException e)
      {
         exception = true;
      }

      assertTrue("exception expected", exception);

      liveServer.crash();

      long timeout = System.currentTimeMillis() + 5000;

      Topic topic = null;
      while (timeout > System.currentTimeMillis())
      {
         try
         {
            topic = (Topic) context.lookup("/myTopic");
         }
         catch (Exception ignored)
         {
            // ignored.printStackTrace();
         }
         if (topic == null)
         {
            Thread.sleep(100);
         }
         else
         {
            break;
         }
      }

      assertNotNull(topic);
   }

   /**
    * Since the back-up server is *not* active the "destroyConnectionFactory" operation should be cached and not run.
    * If it was run we would receive an exception.  This is for HORNETQ-911.
    *
    * @throws Exception
    */
   public void testDestroyConnectionFactory() throws Exception
   {
      boolean exception = false;
      try
      {
         backupJmsServer.destroyConnectionFactory("fakeConnectionFactory");
      }
      catch (Exception e)
      {
         exception = true;
      }

      assertFalse(exception);
   }

   /**
    * Since the back-up server is *not* active the "removeQueueFromJNDI" operation should be cached and not run.
    * If it was run we would receive an exception.  This is for HORNETQ-911.
    *
    * @throws Exception
    */
   public void testRemoveQueue() throws Exception
   {
      boolean exception = false;
      try
      {
         backupJmsServer.removeQueueFromJNDI("fakeQueue");
      }
      catch (Exception e)
      {
         exception = true;
      }

      assertFalse(exception);
   }

   /**
    * Since the back-up server is *not* active the "removeTopicFromJNDI" operation should be cached and not run.
    * If it was run we would receive an exception.  This is for HORNETQ-911.
    *
    * @throws Exception
    */
   public void testRemoveTopic() throws Exception
   {
      boolean exception = false;
      try
      {
         backupJmsServer.removeTopicFromJNDI("fakeTopic");
      }
      catch (Exception e)
      {
         exception = true;
      }

      assertFalse(exception);
   }
}
TOP

Related Classes of org.hornetq.tests.integration.management.ManagementActivationTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.