/*
* JBoss, the OpenSource J2EE webOS
*
* Distributable under LGPL license.
* See terms of license at gnu.org.
*/
package org.jboss.test.naming.ejb;

import javax.ejb.DuplicateKeyException;
import javax.naming.InitialContext;

import org.jboss.test.util.ejb.EJBTestCase;
import org.jboss.test.JBossTestCase;
import org.jboss.test.naming.interfaces.TestENCHome;
import org.jboss.test.naming.interfaces.TestENC;
import org.jboss.test.cts.interfaces.CtsCmpLocalHome;
import org.jboss.test.cts.interfaces.CtsCmpLocal;
import org.jboss.test.cts.keys.AccountPK;
import org.jboss.test.cts.ejb.LocalEjbTests;
import org.jboss.logging.Logger;
import junit.framework.Test;

/** Tests of JNDI ENC performance. The following properties are used:
 * 
 * <ul>
 *    <li>ejbRunnerJndiName, the JNDI name of the EJBTestRunning. Defaults
 *    to EJBTestRunnerHome
 *    </li>
 *    <li>encBeanJndiName, the JNDI name of the ENCBean. Defaults to ENCBean.
 *    </li>
 * </ul>
 * @author Scott.Stark@jboss.org
 * @version $Revision: 1.2.6.1 $
 */
public class NamingTests extends EJBTestCase
{
   Logger log = Logger.getLogger(NamingTests.class);

   public NamingTests(String methodName)
   {
      super(methodName);
   }

   public String getEJBRunnerJndiName()
   {
      String jndiName = "EJBTestRunnerHome";
      if( props != null )
         jndiName = props.getProperty("ejbRunnerJndiName", "EJBTestRunnerHome");
      return jndiName;
   }

   public void testENCPerf() throws Exception
   {
      InitialContext ctx = new InitialContext();
      String name = "ENCBean";
      if( props != null )
         name = props.getProperty("encBeanJndiName", "ENCBean");
      TestENCHome home = (TestENCHome) ctx.lookup(name);
      TestENC bean = home.create();
      int iterations = Integer.getInteger("encIterations", 1000).intValue();
      long time = bean.stressENC(iterations);
      log.info("testENCPerf, time="+time);
      bean.remove();
   }
}