Package org.jboss.test.cluster.defaultcfg.test

Source Code of org.jboss.test.cluster.defaultcfg.test.RPCTestCase

/*
* JBoss, Home of Professional Open Source.
* Copyright 2008, Red Hat Middleware LLC, and individual contributors
* as indicated by the @author tags. See the copyright.txt file 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.cluster.defaultcfg.test;

import java.util.ArrayList;

import javax.management.MBeanServerConnection;
import javax.management.ObjectName;

import junit.framework.Test;

import org.jboss.test.JBossClusteredTestCase;
import org.jboss.test.cluster.hapartition.rpc.Person;
import org.jboss.test.cluster.hapartition.rpc.PersonQuery;

/** Tests of clustered RPC calls
*
* @author Jerry Gauthier
* @version $Revision: 104443 $
*/
public class RPCTestCase extends JBossClusteredTestCase
{
   // must match service names in rpc-tests.sar
   private static final String RPC_SERVICE = "jboss.test:service=RPCTestCase";
   private static final String RPC_ONENODE_SERVICE = "jboss.test:service=RPCOneNodeTestCase";
   private static final String RPC_CLASSLOADER_SERVICE = "jboss.test:service=RPCClassLoaderTestCase";
   private static final String RPC_ONENODE_CLASSLOADER_SERVICE = "jboss.test:service=RPCOneNodeClassLoaderTestCase";
  
   public static Test suite() throws Exception
   {
      Test t1 = getDeploySetup(RPCTestCase.class, "rpc-tests.sar, rpc-cl-tests.sar");
      return t1;
   }

   public RPCTestCase(String name)
   {
      super(name);
   }

   public void testMethodOnCluster() throws Exception
   {
      log.debug("+++ testMethodOnCluster");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server0 = adaptors[0];
      ObjectName rpcService = new ObjectName(RPC_SERVICE);

      Object obj0 = server0.invoke(rpcService, "runRetrieveAll", null, null);
      assertNotNull("expected ArrayList as result type, got null", obj0);
      assertTrue( "expected ArrayList as result type, got " +obj0.getClass().getName(), obj0 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj0;
     
      // there should be two Person responses, the attributes should differ
      assertEquals("Result should contain two responses; ", 2, responses.size());     
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
      }
      Person person0 = (Person)responses.get(0);
      Person person1 = (Person)responses.get(1);
      assertFalse("expected different person names, got " + person0.getName(),
                  person0.getName().equals(person1.getName()));

   }
  
   public void testParmMethodOnCluster() throws Exception
   {
      log.debug("+++ testParmMethodOnCluster");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server1 = adaptors[1];
      ObjectName rpcService = new ObjectName(RPC_SERVICE);
     
      // try using a custom class as parameter
      String employer = "WidgetsRUs";
      PersonQuery query = new PersonQuery();
      query.setEmployer(employer);
      Object[] parms = new Object[]{query};
      String[] types = new String[]{PersonQuery.class.getName()};
     
      Object obj1 = server1.invoke(rpcService, "runRetrieveQuery", parms, types);
      assertNotNull("expected ArrayList as result type, got null", obj1);
      assertTrue( "expected ArrayList as result type, got " +obj1.getClass().getName(), obj1 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj1;
     
      // there should be two responses, a Person and a null value
      assertEquals("Result should contain two responses; ", 2, responses.size());
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         if (response != null)
         {
            assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
            String respEmpl = ((Person)response).getEmployer();
            assertTrue("expected " + employer + " as selected response value, got " + respEmpl,
                        (employer.equalsIgnoreCase(respEmpl)));
         }
      }

   }
  
   public void testAsynchMethodOnCluster() throws Exception
   {
      log.debug("+++ testAsynchMethodOnCluster");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server0 = adaptors[0];
      MBeanServerConnection server1 = adaptors[1];
      ObjectName rpcService = new ObjectName(RPC_SERVICE);
     
      // this will set the 'notified' attribute to true for all Person objects in RPCUser
      server0.invoke(rpcService, "runNotifyAllAsynch", null, null);
      Thread.sleep(5000);
     
      // confirm the attribute has been set successfully on each node
      Object obj1 = server1.invoke(rpcService, "runRetrieveAll", null, null);
      assertNotNull("expected ArrayList as result type, got null", obj1);
      assertTrue( "expected ArrayList as result type, got " +obj1.getClass().getName(), obj1 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj1;
     
      // there should be two Person responses, the 'notified' attribute should be true
      assertEquals("Result should contain two responses; ", 2, responses.size());     
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
         Person person = (Person)response;
         assertTrue("expected true as response value, got false for " + person.getName(),
                     (person.getNotified() == true));
        
      }
   }
  
   public void testMethodOnCoordinatorNode() throws Exception
   {
      log.debug("+++ testMethodOnCoordinatorNode");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server0 = adaptors[0];
      ObjectName rpcService = new ObjectName(RPC_SERVICE);
     
      Object obj0 = server0.invoke(rpcService, "runRetrieveFromCoordinator", null, null);
      assertNotNull("expected Person as result type, got null", obj0);
      assertTrue( "expected Person as result type, got " +obj0.getClass().getName(), obj0 instanceof Person);

      String employer = "WidgetsRUs";
      String respEmpl = ((Person)obj0).getEmployer();
      assertTrue("expected " + employer + " as selected response value, got " + respEmpl,
                  (employer.equalsIgnoreCase(respEmpl)));
   }
  
   public void testMethodOnOneNode() throws Exception
   {
      log.debug("+++ testMethodOnOneNode");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server0 = adaptors[0];
      ObjectName rpcService = new ObjectName(RPC_ONENODE_SERVICE);

      Object obj0 = server0.invoke(rpcService, "runRetrieveAll", null, null);
      assertNotNull("expected ArrayList as result type, got null", obj0);
      assertTrue( "expected ArrayList as result type, got " +obj0.getClass().getName(), obj0 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj0;
     
      // there should be one response as the service is only registered on one node
      assertEquals("Result should contain one response; ", 1, responses.size());     
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
      }

   }
  
   public void testClassLoaderParmMethodOnOneNode() throws Exception
   {
      log.debug("+++ testClassLoaderParmMethodOnOneNode");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server1 = adaptors[1];
      ObjectName rpcService = new ObjectName(RPC_ONENODE_CLASSLOADER_SERVICE);
     
      // try using a custom class as parameter
      String employer = "WidgetsRUs";
      PersonQuery query = new PersonQuery();
      query.setEmployer(employer);
      Object[] parms = new Object[]{query};
      String[] types = new String[]{PersonQuery.class.getName()};
     
      Object obj1 = server1.invoke(rpcService, "runRetrieveQuery", parms, types);
      assertNotNull("expected ArrayList as result type, got null", obj1);
      assertTrue( "expected ArrayList as result type, got " +obj1.getClass().getName(), obj1 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj1;
     
      // there should be one response as the service is only registered on one node
      assertEquals("Result should contain one response; ", 1, responses.size());
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         if (response != null)
         {
            assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
            String respEmpl = ((Person)response).getEmployer();
            assertTrue("expected " + employer + " as selected response value, got " + respEmpl,
                        (employer.equalsIgnoreCase(respEmpl)));
         }
      }

   }
  
   public void testClassLoaderParmMethodOnCluster() throws Exception
   {
      log.debug("+++ testClassLoaderParmMethodOnCluster");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server1 = adaptors[1];
      ObjectName rpcService = new ObjectName(RPC_CLASSLOADER_SERVICE);
     
      // try using a custom class as parameter
      String employer = "WidgetsRUs";
      PersonQuery query = new PersonQuery();
      query.setEmployer(employer);
      Object[] parms = new Object[]{query};
      String[] types = new String[]{PersonQuery.class.getName()};
     
      Object obj1 = server1.invoke(rpcService, "runRetrieveQuery", parms, types);
      assertNotNull("expected ArrayList as result type, got null", obj1);
      assertTrue( "expected ArrayList as result type, got " +obj1.getClass().getName(), obj1 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj1;
     
      // there should be two responses, a Person and a null value
      assertEquals("Result should contain two responses; ", 2, responses.size());
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         if (response != null)
         {
            assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
            String respEmpl = ((Person)response).getEmployer();
            assertTrue("expected " + employer + " as selected response value, got " + respEmpl,
                        (employer.equalsIgnoreCase(respEmpl)));
         }
      }

   }
  
   public void testClassLoaderMethodOnCluster() throws Exception
   {
      log.debug("+++ testClassLoaderMethodOnCluster");
     
      MBeanServerConnection[] adaptors = getAdaptors();
      MBeanServerConnection server0 = adaptors[0];
      ObjectName rpcService = new ObjectName(RPC_CLASSLOADER_SERVICE);

      Object obj0 = server0.invoke(rpcService, "runRetrieveAll", null, null);
      assertNotNull("expected ArrayList as result type, got null", obj0);
      assertTrue( "expected ArrayList as result type, got " +obj0.getClass().getName(), obj0 instanceof ArrayList);
      ArrayList responses = (ArrayList)obj0;
     
      // there should be two Person responses, the attributes should differ
      assertEquals("Result should contain two responses; ", 2, responses.size());     
      for (int i = 0; i < responses.size(); i++)
      {
         Object response = responses.get(i);
         if (response instanceof Exception)
            fail("received exception response: " + ((Exception)response).toString());
         assertTrue("expected Person as response type, got " +response.getClass().getName(), response instanceof Person);
      }
      Person person0 = (Person)responses.get(0);
      Person person1 = (Person)responses.get(1);
      assertFalse("expected different person names, got " + person0.getName(),
                  person0.getName().equals(person1.getName()));

   }

}
TOP

Related Classes of org.jboss.test.cluster.defaultcfg.test.RPCTestCase

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.