dain        2006/02/01 06:50:15

  Modified:    modules/openejb-builder/src/test/org/openejb/deployment/mdb
                        BasicMDBContainerTest.java
  Added:       modules/openejb-builder/src/test/org/openejb/deployment/mdb
                        BasicMdbContainerTest.java
  Log:

  Major refactor
  Split container into an object to represent a deployed ejb and a set of 
shared containers which process invocations
  Introduced interface between CMP container and CMP engine
  
  Revision  Changes    Path
  1.7       +15 -29    
openejb/modules/openejb-builder/src/test/org/openejb/deployment/mdb/BasicMDBContainerTest.java
  
  Index: BasicMDBContainerTest.java
  ===================================================================
  RCS file: 
/home/projects/openejb/scm/openejb/modules/openejb-builder/src/test/org/openejb/deployment/mdb/BasicMDBContainerTest.java,v
  retrieving revision 1.6
  retrieving revision 1.7
  diff -u -r1.6 -r1.7
  --- BasicMDBContainerTest.java        15 Mar 2005 05:32:44 -0000      1.6
  +++ BasicMDBContainerTest.java        1 Feb 2006 11:50:14 -0000       1.7
  @@ -44,52 +44,37 @@
    */
   package org.openejb.deployment.mdb;
   
  -import java.util.HashMap;
  -import java.util.HashSet;
  -
   import junit.framework.TestCase;
   import org.apache.geronimo.gbean.GBeanData;
   import org.apache.geronimo.kernel.Kernel;
   import org.openejb.deployment.DeploymentHelper;
  -import org.openejb.deployment.MDBContainerBuilder;
  -import org.openejb.dispatch.InterfaceMethodSignature;
  -import org.openejb.transaction.TransactionPolicySource;
  -import org.openejb.transaction.TransactionPolicyType;
  +import org.openejb.deployment.MdbBuilder;
   
   /**
    * @version $Revision$ $Date$
    */
  -public class BasicMDBContainerTest extends TestCase {
  +public class BasicMdbContainerTest extends TestCase {
       private Kernel kernel;
  -    private GBeanData container;
   
       protected void setUp() throws Exception {
           super.setUp();
           kernel = DeploymentHelper.setUpKernelWithTransactionManager();
  -        DeploymentHelper.setUpTimer(kernel);
           DeploymentHelper.setUpResourceAdapter(kernel);
   
  -        MDBContainerBuilder builder = new MDBContainerBuilder();
  -        builder.setClassLoader(this.getClass().getClassLoader());
  -        
builder.setContainerId(DeploymentHelper.CONTAINER_NAME.getCanonicalName());
  -        builder.setEJBName("MockEJB");
  -        builder.setBeanClassName(MockEJB.class.getName());
  +        MdbBuilder builder = new MdbBuilder();
  +        builder.setContainerId(DeploymentHelper.CONTAINER_NAME);
  +        builder.setEjbName("MockEJB");
  +
           builder.setEndpointInterfaceName("javax.jms.MessageListener");
  +        builder.setBeanClassName(MockEJB.class.getName());
  +
           builder.setActivationSpecName(DeploymentHelper.ACTIVATIONSPEC_NAME);
  -        builder.setUnshareableResources(new HashSet());
  -        builder.setTransactionPolicySource(new TransactionPolicySource() {
  -            public TransactionPolicyType getTransactionPolicy(String 
methodIntf, InterfaceMethodSignature signature) {
  -                return TransactionPolicyType.Required;
  -            }
  -        });
  -        builder.setComponentContext(new HashMap());
  -        container = builder.createConfiguration();
  +
  +        builder.setEjbContainerName(DeploymentHelper.MDB_EJB_CONTAINER_NAME);
  +
  +        GBeanData container = builder.createConfiguration();
           container.setName(DeploymentHelper.CONTAINER_NAME);
   
  -        //start the ejb container
  -        container.setReferencePattern("TransactionContextManager", 
DeploymentHelper.TRANSACTIONCONTEXTMANAGER_NAME);
  -        container.setReferencePattern("TrackedConnectionAssociator", 
DeploymentHelper.TRACKEDCONNECTIONASSOCIATOR_NAME);
  -        container.setReferencePattern("Timer", 
DeploymentHelper.TRANSACTIONALTIMER_NAME);
           kernel.loadGBean(container, getClass().getClassLoader());
           kernel.startGBean(DeploymentHelper.CONTAINER_NAME);
       }
  @@ -100,6 +85,7 @@
           DeploymentHelper.stop(kernel, 
DeploymentHelper.TRACKEDCONNECTIONASSOCIATOR_NAME);
           DeploymentHelper.tearDownAdapter(kernel);
           kernel.shutdown();
  +        super.tearDown();
       }
   
   
  
  
  
  1.1                  
openejb/modules/openejb-builder/src/test/org/openejb/deployment/mdb/BasicMdbContainerTest.java
  
  Index: BasicMdbContainerTest.java
  ===================================================================
  /**
   * Redistribution and use of this software and associated documentation
   * ("Software"), with or without modification, are permitted provided
   * that the following conditions are met:
   *
   * 1. Redistributions of source code must retain copyright
   *    statements and notices.  Redistributions must also contain a
   *    copy of this document.
   *
   * 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 name "OpenEJB" must not be used to endorse or promote
   *    products derived from this Software without prior written
   *    permission of The OpenEJB Group.  For written permission,
   *    please contact [EMAIL PROTECTED]
   *
   * 4. Products derived from this Software may not be called "OpenEJB"
   *    nor may "OpenEJB" appear in their names without prior written
   *    permission of The OpenEJB Group. OpenEJB is a registered
   *    trademark of The OpenEJB Group.
   *
   * 5. Due credit should be given to the OpenEJB Project
   *    (http://openejb.org/).
   *
   * THIS SOFTWARE IS PROVIDED BY THE OPENEJB GROUP AND CONTRIBUTORS
   * ``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 OPENEJB GROUP 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.
   *
   * Copyright 2001 (C) The OpenEJB Group. All Rights Reserved.
   *
   * $Id: BasicMdbContainerTest.java,v 1.1 2006/02/01 11:50:14 dain Exp $
   */
  package org.openejb.deployment.mdb;
  
  import junit.framework.TestCase;
  import org.apache.geronimo.gbean.GBeanData;
  import org.apache.geronimo.kernel.Kernel;
  import org.openejb.deployment.DeploymentHelper;
  import org.openejb.deployment.MdbBuilder;
  
  /**
   * @version $Revision: 1.1 $ $Date: 2006/02/01 11:50:14 $
   */
  public class BasicMdbContainerTest extends TestCase {
      private Kernel kernel;
  
      protected void setUp() throws Exception {
          super.setUp();
          kernel = DeploymentHelper.setUpKernelWithTransactionManager();
          DeploymentHelper.setUpResourceAdapter(kernel);
  
          MdbBuilder builder = new MdbBuilder();
          builder.setContainerId(DeploymentHelper.CONTAINER_NAME);
          builder.setEjbName("MockEJB");
  
          builder.setEndpointInterfaceName("javax.jms.MessageListener");
          builder.setBeanClassName(MockEJB.class.getName());
  
          builder.setActivationSpecName(DeploymentHelper.ACTIVATIONSPEC_NAME);
  
          builder.setEjbContainerName(DeploymentHelper.MDB_EJB_CONTAINER_NAME);
  
          GBeanData container = builder.createConfiguration();
          container.setName(DeploymentHelper.CONTAINER_NAME);
  
          kernel.loadGBean(container, getClass().getClassLoader());
          kernel.startGBean(DeploymentHelper.CONTAINER_NAME);
      }
  
      protected void tearDown() throws Exception {
          DeploymentHelper.stop(kernel, DeploymentHelper.CONTAINER_NAME);
          DeploymentHelper.stop(kernel, 
DeploymentHelper.TRANSACTIONMANAGER_NAME);
          DeploymentHelper.stop(kernel, 
DeploymentHelper.TRACKEDCONNECTIONASSOCIATOR_NAME);
          DeploymentHelper.tearDownAdapter(kernel);
          kernel.shutdown();
          super.tearDown();
      }
  
  
      public void testMessage() throws Exception {
          // @todo put a wait limit in here... otherwise this can lock a build
          // Wait for 3 messages to arrive..
          System.out.println("Waiting for message 1");
          assertTrue(MockEJB.messageCounter.attempt(10000));
          System.out.println("Waiting for message 2");
          assertTrue(MockEJB.messageCounter.attempt(10000));
          System.out.println("Waiting for message 3");
          assertTrue(MockEJB.messageCounter.attempt(10000));
  
          System.out.println("Done.");
          assertTrue("Timer should have fired once by now...", 
MockEJB.timerFired);
      }
  }
  
  
  

Reply via email to