Package org.apache.jmeter.ejb.jndi.sampler

Source Code of org.apache.jmeter.ejb.jndi.sampler.JNDISampler

/*
* ====================================================================
* The Apache Software License, Version 1.1
*
* Copyright (c) 2001 The Apache Software Foundation.  All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The end-user documentation included with the redistribution,
* if any, must include the following acknowledgment:
* "This product includes software developed by the
* Apache Software Foundation (http://www.apache.org/)."
* Alternately, this acknowledgment may appear in the software itself,
* if and wherever such third-party acknowledgments normally appear.
*
* 4. The names "Apache" and "Apache Software Foundation" and
* "Apache JMeter" must not be used to endorse or promote products
* derived from this software without prior written permission. For
* written permission, please contact apache@apache.org.
*
* 5. Products derived from this software may not be called "Apache",
* "Apache JMeter", nor may "Apache" appear in their name, without
* prior written permission of the Apache Software Foundation.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of the Apache Software Foundation.  For more
* information on the Apache Software Foundation, please see
* <http://www.apache.org/>.
*/
package org.apache.jmeter.ejb.jndi.sampler;

import java.lang.reflect.Method;
import java.lang.reflect.InvocationTargetException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Hashtable;
import java.util.Map;
import java.util.Vector;

import javax.naming.InitialContext;
import javax.naming.NamingException;

import org.apache.jmeter.ejb.jndi.config.JndiConfig;
import org.apache.jmeter.ejb.jndi.config.LookupConfig;
import org.apache.jmeter.ejb.jndi.config.MethodConfig;
import org.apache.jmeter.ejb.jndi.config.MethodConfigUserObjectException;
import org.apache.jmeter.ejb.jndi.config.gui.MethodConfigGui;
import org.apache.jmeter.samplers.Entry;
import org.apache.jmeter.samplers.Sampler;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.log4j.Category;
/**
* Samples the JNDI performance and records them
*
* @author  Khor Soon Hin
* @created  2001 Dec 18
* @modified  2002 Feb 16
*/
public class JNDISampler implements Sampler
{
  private static Category catClass = Category.getInstance(
  JNDISampler.class.getName());

  public static final String QUERY = "JNDISampler.query";

  protected static Map keyMap = new HashMap();

  public JNDISampler()
  {
  }

  /**
   * The main method which samples and records the JNDI performance
   *
   * @param e  the JNDI sampling configuration
   * @return  the measurements captured
   */
  public SampleResult sample(Entry e)
  {
    catClass.info("Start : sample1");
    boolean reflectionStatus = false;
    // There is a row of ifs condition which may be executed depending on the
    // state of the MethodConfig state.  During reflection only one of these
    // condition should be become true.  However, once one condition becomes
    // true it will set the MethodConfig state and this will cause the next
    // condition to become true and so on.  Thus else-ifs should be used BUT
    // these same conditions need to be used such that more than one condition
    // can be true during sampling so ifs and NOT else-ifs must be used.  To
    // resolve this conflict, ifs are used with stateJustChange is used to act
    // like else-if
    boolean stateJustChanged = false;
    long start = (long)0;
    long end = (long)0;
    long ctxTime = (long)0;
    long lookupTime = (long)0;
    long homeMethodTime = (long)0;
    long remoteMethodTime = (long)0;

    Object remoteInterface = null;
    Object results = null;
    Object ref = null;
   
    SampleResult res = new SampleResult();
    SampleResult contextLookupRes = new SampleResult();
    contextLookupRes.putValue(SampleResult.DISPLAY_NAME, "Context Lookup");
    SampleResult lookupRes = new SampleResult();
    SampleResult homeMethodRes = null;
    SampleResult remoteMethodRes = null;
    Hashtable ht = new Hashtable();
    JndiConfig jndiConfig = null;
    InitialContext ctx = null;
    try
    {
      jndiConfig = (JndiConfig)e.getConfigElement(JndiConfig.class);
      // check if InitialContext is already obtained previously
      ctx = jndiConfig.getInitialContext();
      if(ctx == null)
      {
        // setup the hashtable
        for(int i = 0 ; i < JndiConfig.JNDI_PROPS.length; i++)
        {
          String value = jndiConfig.getValue(i);
          if(value != null)
          {
            if(catClass.isDebugEnabled())
            {
              catClass.debug("sample1 : JNDI env - " +
    JndiConfig.JNDI_PROPS[i] + " = " + value);
            }
            ht.put(JndiConfig.JNDI_PROPS[i], value);
          }
        }
        // initialize initial context
        start = System.currentTimeMillis();
        ctx = new InitialContext(ht);
        end = System.currentTimeMillis();
        catClass.info("sample1 : Got initial context");
        // store the initial context for reuse
        jndiConfig.setInitialContext(ctx);
      }
      // set the initial context lookup time
      ctxTime = end - start;
      contextLookupRes.setTime(ctxTime);

      // look up the name
      LookupConfig lookupConfig =
    (LookupConfig)e.getConfigElement(LookupConfig.class);
      String lookupName = null;
      if(lookupConfig != null)
      {
        lookupName = lookupConfig.getLookupName();
        if(catClass.isDebugEnabled())
        {
          catClass.debug("sample1 : LookupName - " + lookupName);
        }
        start = System.currentTimeMillis();
        ref = ctx.lookup(lookupName);
        end = System.currentTimeMillis();
        lookupTime = end - start;
        catClass.info("Got remote interface");
        lookupRes.setTime(lookupTime);
        lookupRes.putValue(SampleResult.DISPLAY_NAME,
    "Remote Interface Lookup - " + lookupName);
      }
      Class lookupNameClass = ref.getClass();
      // lookup method name
      MethodConfig methodConfig =
    (MethodConfig)e.getConfigElement(MethodConfig.class);
      // store all reflections result in the model of the gui and not the
      // MethodConfig obtained from getConfigElement() 'cos that's the clone.
      // To get the model of the MethodConfigGui, get the MethodConfigGui
      // from the MethodConfig clone first.  All MethodConfig clones cloned
      // from the same MethodConfig shares the same MethodConfigGui.
      MethodConfigGui methodConfigGui =  methodConfig.getGui();
      MethodConfig model = methodConfigGui.getModel();
      // Make all changes on the model of the gui and not the MethodConfig
      // obtained from getConfigElement() because that is the clone.
      int state = model.getState();
      reflectionStatus = model.getReflectionStatus();
      String[] strings = null;
      if(catClass.isDebugEnabled())
      {
        catClass.debug("sample1 : state - " + state);
        catClass.debug("sample1 : reflectionStatus - " + reflectionStatus);
      }
      // Perform only if :
      // 1. doing a reflection and in this state
      // 2. sampling does not perform this step
      if((state == MethodConfig.METHOD_GET_HOME_NAMES && reflectionStatus
  && !stateJustChanged))
//  || (state >= MethodConfig.METHOD_GET_HOME_NAMES && !reflectionStatus))
      {
        // for this state, get the list of all methods in the home
        // interface
        Method[] methods = lookupNameClass.getMethods();
        strings = new String[methods.length];
        for(int i = 0; i < methods.length; i++)
        {
          // create method name which includes method signatures
          strings[i] = getMethodSignature(methods[i]);
        }
        model.setMethodHomeList(strings);
        model.setState(MethodConfig.METHOD_GET_HOME_PARMS);
        stateJustChanged = true;
      }
      // Perform only if :
      // 1. doing a reflection and in this state
      // 2. sampling does not perform this step
      if((state == MethodConfig.METHOD_GET_HOME_PARMS && reflectionStatus
  && !stateJustChanged))
//  || (state >= MethodConfig.METHOD_GET_HOME_PARMS && !reflectionStatus))
      {
        // for this state, get all the required parms for the selected
        // method
        String methodHomeName = methodConfig.getMethodHomeName();
        if(catClass.isDebugEnabled())
        {
          catClass.debug("sample1 : selected methodHomeName - " +
    methodHomeName);
        }
        Vector returnValues =
    getMethodParmsTypes(methodHomeName, lookupNameClass);
        // the first object of returnValues will be the Method while the
        // the second object will be the parm types of Method
        Method method = (Method)returnValues.get(0);
        Class[] methodParmTypes = (Class[])returnValues.get(1);
        // once the method is obtained store the parms
        model.setMethodHomeParms(methodParmTypes);
        model.setHomeMethod(method);
        model.setState(MethodConfig.METHOD_INVOKE_HOME);
        stateJustChanged = true;
      }
      // Perform only if :
      // 1. doing a reflection and in this state
      // 2. sampling and reflection has been done at least this state
      //    if reflection has not been done till this state then user is not
      //    interested in sampling till this state
      if((state == MethodConfig.METHOD_INVOKE_HOME && reflectionStatus
  && !stateJustChanged)
  || (state >= MethodConfig.METHOD_INVOKE_HOME && !reflectionStatus))
      {
        catClass.debug("sample1 : METHOD_INVOKE_HOME");
        Method method = model.getHomeMethod();
        if(catClass.isDebugEnabled())
        {
          catClass.debug("sample1 : home method to be invoked - " + method);
        }
        // only initialize homeMethodRes if method execution is to be measured
        homeMethodRes = new SampleResult();
        // gather all parms from MethodConfigGui
        Object[] parmsArray = null;
        try
        {
          parmsArray = methodConfigGui.getMethodParmsValues(
    MethodConfig.METHOD_INVOKE_HOME);
          if(catClass.isDebugEnabled())
          {
            catClass.debug("sample1 : home method parms - " + parmsArray);
          }
          // invoke the method
          start = System.currentTimeMillis();
          remoteInterface = method.invoke(ref, parmsArray);
System.out.println("return - " + remoteInterface);
        }
        catch(IllegalAccessException err)
        {
          catClass.error(err);
          System.out.println(err);
        }
        catch(InvocationTargetException err)
        {
          catClass.error(err);
          System.out.println(err);
        }
        catch(MethodConfigUserObjectException err)
        {
          catClass.error(err);
          System.out.println(err);
        }
        end = System.currentTimeMillis();
        if(!reflectionStatus)
        {
          // if sampling then get the time lapsed
          homeMethodTime = end - start;
          homeMethodRes.setTime(homeMethodTime);
          homeMethodRes.putValue(SampleResult.DISPLAY_NAME, "Home Method Execution - "
                + method.getName());
          homeMethodRes.putValue(SampleResult.SUCCESS, new Boolean(true));
        }
        else
        {
          // if reflection then get all the info required
          model.setState(MethodConfig.METHOD_GET_REMOTE_NAMES);
          stateJustChanged = true;
          // store list of remote interfaces returned
          model.setRemoteInterfaceList(remoteInterface);
        }
      }
      // Perform only if :
      // 1. doing a reflection and in this state
      // 2. sampling does NOT perform this step
      if((state == MethodConfig.METHOD_GET_REMOTE_NAMES && reflectionStatus
  && !stateJustChanged))
//  || (state >= MethodConfig.METHOD_GET_REMOTE_NAMES && !reflectionStatus))
      {
        // for this state, get the list of all methods in the remote
        // interface
        remoteInterface = model.getRemoteInterfaceType();
        Class remoteInterfaceClass = remoteInterface.getClass();
        if(catClass.isDebugEnabled())
        {
          catClass.debug("updateGui1 : remoteInterfaceClass - " +
    remoteInterfaceClass);
        }
        Method[] methods = remoteInterfaceClass.getMethods();
        strings = new String[methods.length];
        for(int i = 0; i < methods.length; i++)
        {
          strings[i] = getMethodSignature(methods[i]);
        }
        model.setMethodRemoteList(strings);
        model.setState(MethodConfig.METHOD_GET_REMOTE_PARMS);
        stateJustChanged = true;
      }
      // Perform only if :
      // 1. doing a reflection and in this state
      // 2. sampling does NOT perform this step
      if((state == MethodConfig.METHOD_GET_REMOTE_PARMS && reflectionStatus
  && !stateJustChanged))
//  || (state >= MethodConfig.METHOD_GET_REMOTE_PARMS && !reflectionStatus))
      {
        // for this state, get all the required parms for the selected
        // method
        String methodRemoteName = methodConfig.getMethodRemoteName();
        if(catClass.isDebugEnabled())
        {
          catClass.debug("sample1 : selected methodRemoteName - " +
    methodRemoteName);
        }
        Object selectedRemoteInterfaceType = model.getRemoteInterfaceType();
        Class selectedRemoteInterfaceTypeClass =
    selectedRemoteInterfaceType.getClass();
        Vector returnValues = getMethodParmsTypes(methodRemoteName,
    selectedRemoteInterfaceTypeClass);
        // the first object of returnValues contains the Method while the
        // the second object the parm types of the Method
        Method method = (Method)returnValues.get(0);
        Class[] methodParmTypes = (Class[])returnValues.get(1);
        // once the method is obtained store the parms
        model.setMethodRemoteParms(methodParmTypes);
        model.setRemoteMethod(method);
        model.setState(MethodConfig.METHOD_INVOKE_REMOTE);
        stateJustChanged = true;
      }
      // Perform only if :
      // 1. doing a reflection and in this state
      // 2. sampling and reflection has been done at least this state
      //    if reflection has not been done till this state then user is not
      //    interested in sampling till this state
      if((state == MethodConfig.METHOD_INVOKE_REMOTE && reflectionStatus
  && !stateJustChanged)
  || (state >= MethodConfig.METHOD_INVOKE_REMOTE && !reflectionStatus))
      {
        catClass.debug("sample1 : METHOD_INVOKE_REMOTE");
        Method method = model.getRemoteMethod();
        if(catClass.isDebugEnabled())
        {
          catClass.debug("sample1 : remote method to be invoked - " + method);
        }
        Object selectedRemoteInterfaceType = model.getRemoteInterfaceType();
        // only initialize homeMethodRes if method execution is to be measured
        remoteMethodRes = new SampleResult();
        // gather all parms from MethodConfigGui
        Object[] parmsArray = null;
        try
        {
          parmsArray = methodConfigGui.getMethodParmsValues(
    MethodConfig.METHOD_INVOKE_REMOTE);
          // invoke the method
          start = System.currentTimeMillis();
          results = method.invoke(selectedRemoteInterfaceType, parmsArray);
System.out.println("return - " + results);
        }
        catch(IllegalAccessException err)
        {
          catClass.error(err);
          System.out.println(err);
        }
        catch(InvocationTargetException err)
        {
          catClass.error(err);
          System.out.println(err);
        }
        catch(MethodConfigUserObjectException err)
        {
          catClass.error(err);
          System.out.println(err);
        }
        end = System.currentTimeMillis();
        if(!reflectionStatus)
        {
          // if sampling get the time lapse
          remoteMethodTime = end - start;
          remoteMethodRes.setTime(remoteMethodTime);
          remoteMethodRes.putValue(SampleResult.DISPLAY_NAME, "Remote Method Execution - "
                + method.getName());
          String resultsString = results.toString();
          byte[] resultBytes = null;
          if(resultsString != null)
          {
            resultBytes = resultsString.getBytes();
          }
          remoteMethodRes.putValue(SampleResult.TEXT_RESPONSE, resultBytes);
          remoteMethodRes.putValue(SampleResult.SUCCESS, new Boolean(true));
        }
        else
        {
          // if reflection the set state
          model.setState(MethodConfig.METHOD_COMPLETE);
          stateJustChanged = true;
        }
      }

      long totalTime = ctxTime + lookupTime + homeMethodTime + remoteMethodTime;
      res.setTime(0);
      res.putValue(SampleResult.DISPLAY_NAME, lookupName);
      ArrayList resultList = new ArrayList();
      // don't need to test for null in contextLookupRes and lookupRes
      // because both cannot be null otherwise error will be thrown
      resultList.add(contextLookupRes);
      resultList.add(lookupRes);
      // test for null in homeMethodRes 'cos a null means that user just want
      // to get a list of all home methods
      if(homeMethodRes != null)
      {
        resultList.add(homeMethodRes);
      }
      // test for null in remoteMethodRes 'cos a null means that user just want
      // to get a list of all methods of the remote interfaces
      if(remoteMethodRes != null)
      {
        resultList.add(remoteMethodRes);
      }
      res.putValue(SampleResult.RESULT_LIST, resultList);
      res.putValue(SampleResult.TOTAL_TIME, new Long(totalTime));

      System.out.println("!!!!! ctxTime : " + ctxTime);
      System.out.println("!!!!! lookupTime : " + lookupTime);
      System.out.println("!!!!! homeMethodTime : " + homeMethodTime);
    }
    catch(NamingException err)
    {
      catClass.error(err);
      System.err.println(err);
    }
   
    catClass.info("End : sample1");
    return res;
  }

  /**
   * From the <code>Method</code>, return the method signature i.e.
   * method name followed by all the parms separated by commas and within
   * parentheses
   *
   * @param method  the method which the method signature is required
   * @return  method signature of the method
   */
  protected String getMethodSignature(Method method)
  {
    catClass.debug("Start : getMethodSignature1");
    StringBuffer strbuff = new StringBuffer();
    Class[] parameterTypes = method.getParameterTypes();
    strbuff.append(method.getName());
    strbuff.append("(");
    if(parameterTypes.length > 0)
    {
      for(int j = 0; j < (parameterTypes.length - 1); j++)
      {
        strbuff.append(parameterTypes[j].toString());
        strbuff.append(", ");
      }
      strbuff.append(parameterTypes[parameterTypes.length - 1]);
    }
    strbuff.append(")");
    String returnVal = strbuff.toString();
    catClass.debug("getMethodSignature1 : method signature - " + returnVal);
    catClass.debug("End : getMethodSignature1");
    return returnVal;
  }

  /**
   * Given a method name and a class, compares the method name against all
   * the methods in the class to look for a match.  Once found, return an
   * array containing all the Class of the parms of the method.
   */
  protected Vector getMethodParmsTypes(String methodName, Class objectClass)
  {
    catClass.debug("Start : getMethodParms1");
    Method[] methods = objectClass.getMethods();
    Method method = null;
    Class[] methodParmTypes = null;
    Class[] parameterTypes = null;
    StringBuffer strbuff = new StringBuffer();
    for(int i = 0; i < methods.length; i++)
    {
      // create method name which includes method signatures
      parameterTypes = methods[i].getParameterTypes();
      strbuff.delete(0, strbuff.length());
      strbuff.append(methods[i].getName());
      strbuff.append("(");
      if(parameterTypes.length > 0)
      {
        for(int j = 0; j < (parameterTypes.length - 1); j++)
        {
          strbuff.append(parameterTypes[j].toString());
          strbuff.append(", ");
        }
        strbuff.append(parameterTypes[parameterTypes.length - 1]);
      }
      strbuff.append(")");
      String name = strbuff.toString();
      if(catClass.isDebugEnabled())
      {
        catClass.debug("getMethodParms1 : current method to be compared - "
    + name);
      }
      if(name.equals(methodName))
      {
        method = methods[i];
        methodParmTypes = parameterTypes;
        break;
      }
    }
    Vector returnValues = new Vector();
    returnValues.add(method);
    returnValues.add(methodParmTypes);
    catClass.debug("End : getMethodParms1");
    return returnValues;
  }
}
TOP

Related Classes of org.apache.jmeter.ejb.jndi.sampler.JNDISampler

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.