Package org.jboss.test.remoting.connection

Source Code of org.jboss.test.remoting.connection.ConnectionValidatorConfigTestClient

/*
* JBoss, Home of Professional Open Source
* Copyright 2005, JBoss Inc., and individual contributors as indicated
* 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.remoting.connection;

import java.lang.reflect.Field;
import java.util.HashMap;
import java.util.Map;

import javax.management.MBeanServer;

import junit.framework.TestCase;

import org.apache.log4j.Logger;
import org.jboss.remoting.AbstractInvoker;
import org.jboss.remoting.Client;
import org.jboss.remoting.ConnectionListener;
import org.jboss.remoting.ConnectionValidator;
import org.jboss.remoting.InvocationRequest;
import org.jboss.remoting.InvokerLocator;
import org.jboss.remoting.ServerInvocationHandler;
import org.jboss.remoting.ServerInvoker;
import org.jboss.remoting.callback.InvokerCallbackHandler;
import org.jboss.remoting.transport.socket.MicroSocketClientInvoker;


/**
*
* @author <a href="ron.sigal@jboss.com">Ron Sigal</a>
* @version $Revision: 4740 $
* <p>
* Copyright Jun 15, 2007
* </p>
*/
public class ConnectionValidatorConfigTestClient extends TestCase
{
   public static int port;
  
   private static Logger log = Logger.getLogger(ConnectionValidatorConfigTestClient.class);
   private static boolean firstTime = true;
   private static InvokerLocator serverLocator;

  
   /**
    * Sets up target remoting server.
    */
   public void setUp() throws Exception
   {
      if (firstTime)
      {
         firstTime = false;
         serverLocator = new InvokerLocator(ConnectionValidatorConfigTestServer.serverLocatorURI);
      }
   }

  
   public void tearDown()
   {
   }
  
  
   /**
    * Verifies that the default values are set correctly if a call is made to
    * Client.addConnectionListener(ConnectionListener listener).
    */
   public void testDefaultConfig() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that pingPeriod is set correctly if a call is made to
    * Client.addConnectionListener(ConnectionListener listener, int pingPeriod).
    */
   public void testSetPingPeriod() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, 3456);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(3456, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that pingPeriod is set correctly if it appears in Client
    * configuration map but Client.addConnectionListener(ConnectionListener listener)
    * puts default value in metadata map.
    */
   public void testSetPingPeriodByClientConfigUsingSingleArgMethod() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      clientConfig.put(ConnectionValidator.VALIDATOR_PING_PERIOD, "3468");
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(3468, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
 
  
   /**
    * Verifies that pingPeriod is set correctly if it appears in Client
    * configuration map.
    */
   public void testSetPingPeriodByClientConfig() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      clientConfig.put(ConnectionValidator.VALIDATOR_PING_PERIOD, "3468");
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(3468, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that pingPeriod is set correctly if a call is made to
    * Client.addConnectionListener(ConnectionListener listener, Map metadata).
    */
   public void testSetPingPeriodByMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put(ConnectionValidator.VALIDATOR_PING_PERIOD, "3467");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(3467, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that pingPeriod is set correctly if it appears in both Client
    * configuration map and metadata map.
    */
   public void testSetPingPeriodByClientConfigAndMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      clientConfig.put(ConnectionValidator.VALIDATOR_PING_PERIOD, "3413");
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put(ConnectionValidator.VALIDATOR_PING_PERIOD, "3414");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(3414, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that timeout is set correctly if it is set in Client
    * configuration map.
    */
   public void testSetTimeoutByClientConfig() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      clientConfig.put(ConnectionValidator.VALIDATOR_PING_TIMEOUT, "3546");
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals("3546", o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);    
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that "timeout" in Client configuration map and metadata is ignored.
    */
   public void testDefaultTimeoutWithStandardTimeoutInClientConfig() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      clientConfig.put(ServerInvoker.TIMEOUT, ConnectionValidator.DEFAULT_PING_TIMEOUT + "0");
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put(ServerInvoker.TIMEOUT, ConnectionValidator.DEFAULT_PING_TIMEOUT + "1");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);    
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that timeout is set correctly if a call is made to
    * Client.addConnectionListener(ConnectionListener listener, Map metadata).
    */
   public void testSetTimeoutByMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put(ConnectionValidator.VALIDATOR_PING_TIMEOUT, "3478");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals("3478", o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);    
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that timeout is set correctly if "validatorPingTimeout" appears in
    * both Client configuration map and metadata map.
    */
   public void testSetTimeoutByClientConfigAndMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      clientConfig.put(ConnectionValidator.VALIDATOR_PING_TIMEOUT, "3167");
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put(ConnectionValidator.VALIDATOR_PING_TIMEOUT, "3168");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals("3168", o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);    
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that number of ping retries is set correctly if it appears in
    * Client configuratin map.
    */
   public void testSetPingRetriesClientConfig() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      clientConfig.put("NumberOfCallRetries", "13");
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      assertEquals(13, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that number of ping retries is set correctly if a call is made to
    * Client.addConnectionListener(ConnectionListener listener, Map metadata).
    */
   public void testSetPingRetriesByMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put("NumberOfCallRetries", "7");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      assertEquals(7, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that number of ping retries is set correctly if it appears in both
    * Client configuration map and metadata.
    */
   public void testSetPingRetriesByClientConfigAndMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      clientConfig.put("NumberOfCallRetries", "17");
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put("NumberOfCallRetries", "19");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      assertEquals(19, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that number of connection retries is set correctly if it appears
    * in Client configuration map.
    */
   public void testSetConnectionRetriesByClientConfig() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      clientConfig.put("NumberOfRetries", "21");
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that number of connection retries is set correctly if a call is made to
    * Client.addConnectionListener(ConnectionListener listener, Map metadata).
    */
   public void testSetConnectionRetriesByMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put("NumberOfRetries", "27");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that number of connection retries is set correctly if it appears
    * in Client configuration map.
    */
   public void testSetConnectionRetriesByClientConfigAndMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      clientConfig.put("NumberOfRetries", "31");
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put("NumberOfRetries", "33");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());
        
      client.disconnect();
   }
  
  
   /**
    * Verifies that other parameters may be set by passing in metadata map.
    */
   public void testOtherParamsByMetadata() throws Throwable
   {
      log.info("entering " + getName());
     
      // Create client.
      HashMap clientConfig = new HashMap();
      addExtraClientConfig(clientConfig);
      Client client = new Client(serverLocator, clientConfig);
      client.connect();
      log.info("client is connected");
     
      // Test connection.
      assertEquals("abc", client.invoke("abc"));
     
      // Add connection listener.
      Map metadata = new HashMap();
      metadata.put("ReuseAddress", "false");
      ConnectionListener listener = new TestConnectionListener();
      client.addConnectionListener(listener, metadata);
     
      // Test pingPeriod.
      Field field = Client.class.getDeclaredField("connectionValidator");
      field.setAccessible(true);
      ConnectionValidator validator = (ConnectionValidator) field.get(client);
      field = ConnectionValidator.class.getDeclaredField("pingPeriod");
      field.setAccessible(true);
      long pingPeriod = ((Long) field.get(validator)).longValue();
      assertEquals(ConnectionValidator.DEFAULT_PING_PERIOD, pingPeriod);
     
      // Test timeout.
      field = ConnectionValidator.class.getDeclaredField("clientInvoker");
      field.setAccessible(true);
      AbstractInvoker invoker = (AbstractInvoker) field.get(validator);
      field = AbstractInvoker.class.getDeclaredField("configuration");
      field.setAccessible(true);
      Map config = (Map) field.get(invoker);
      Object o = config.get(ServerInvoker.TIMEOUT);
      assertEquals(ConnectionValidator.DEFAULT_PING_TIMEOUT, o);
     
      // Test ping retries.
      assertTrue(invoker instanceof MicroSocketClientInvoker);
      MicroSocketClientInvoker socketInvoker = (MicroSocketClientInvoker) invoker;
      int defaultPingRetries = Integer.parseInt(ConnectionValidator.DEFAULT_NUMBER_OF_PING_RETRIES);
      assertEquals(defaultPingRetries, socketInvoker.getNumberOfCallRetries());

      // Test ReuseAddress.
      assertFalse(socketInvoker.getReuseAddress());
        
      client.disconnect();
   }
  
  
   protected String getTransport()
   {
      return "socket";
   }
  
  
   protected void addExtraClientConfig(Map config) {}
   protected void addExtraServerConfig(Map config) {}
  

   static class TestInvocationHandler implements ServerInvocationHandler
   {
      public void addListener(InvokerCallbackHandler callbackHandler) {}
      public Object invoke(final InvocationRequest invocation) {return invocation.getParameter();}
      public void removeListener(InvokerCallbackHandler callbackHandler) {}
      public void setMBeanServer(MBeanServer server) {}
      public void setInvoker(ServerInvoker invoker) {}
   }

   static class TestConnectionListener implements ConnectionListener
   {
      public void handleConnectionException(Throwable throwable, Client client) {}
   }
}
TOP

Related Classes of org.jboss.test.remoting.connection.ConnectionValidatorConfigTestClient

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.