EJBTestRunner.java |
/* * JBoss, the OpenSource J2EE webOS * * Distributable under LGPL license. * See terms of license at gnu.org. */ package org.jboss.test.util.ejb; import java.rmi.RemoteException; import java.util.Properties; import javax.ejb.EJBObject; /** * The remote interface of the server side test runner. The EJBTestClient calls * run with the names of the test class and test method to execute. Then run * calls setUpEJB, runTestCase, and tearDownEJB in sepperate transactions. In * order for the the tests to run as expected by the client the EJBTestRunner * bean must be setup exactly as follows in the ejb-jar.xml file: * <pre> * <?xml version="1.0"?> * <!DOCTYPE ejb-jar PUBLIC * "-//Sun Microsystems, Inc.//DTD Enterprise JavaBeans 2.0//EN" * "http://java.sun.com/j2ee/dtds/ejb-jar_2_0.dtd"> * <ejb-jar> * <enterprise-beans> * <session> * <description>JUnit Session Bean Test Runner</description> * <ejb-name>EJBTestRunnerEJB</ejb-name> * <home>net.sourceforge.junitejb.EJBTestRunnerHome</home> * <remote>net.sourceforge.junitejb.EJBTestRunner</remote> * <ejb-class>net.sourceforge.junitejb.EJBTestRunnerBean</ejb-class> * <session-type>Stateless</session-type> * <transaction-type>Bean</transaction-type> * </session> * </enterprise-beans> * </ejb-jar> * </pre> * * Additionally, the home interface must be bount to the jndi name: * "ejb/EJBTestRunner" * * It is recomended that the test classes and the classes of JUnitEJB be * packaged into a single jar. * * @see EJBTestCase * * @author <a href="mailto:dain@daingroup.com">Dain Sundstrom</a> * @author Scott.Stark@jboss.org * @version $Revision: 1.3.6.1 $ */ public interface EJBTestRunner extends EJBObject { /** Runs the specified test method on the specified class by calling * run(className, methodName, props) with props built from the java:comp/env * bindings. * * @param className the name of the test class * @param methodName the name of the test method * @throws RemoteTestException If any throwable is thrown during execution * of the method, it is wrapped with a RemoteTestException and rethrown. */ public void run(String className, String methodName) throws RemoteTestException, RemoteException; /** * Runs the specified test method on the specified class. * @param className the name of the test class * @param methodName the name of the test method * @param props any properties passed in from the client for use by the * server side tests * @throws RemoteTestException If any throwable is thrown during execution * of the method, it is wrapped with a RemoteTestException and rethrown. */ public void run(String className, String methodName, Properties props) throws RemoteTestException, RemoteException; }
EJBTestRunner.java |