[jboss-cvs] JBossAS SVN: r69885 - projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test.

jboss-cvs-commits at lists.jboss.org jboss-cvs-commits at lists.jboss.org
Mon Feb 18 10:54:59 EST 2008


Author: alesj
Date: 2008-02-18 10:54:59 -0500 (Mon, 18 Feb 2008)
New Revision: 69885

Added:
   projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/ClassLoaderDependenciesTest.java
   projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/UndeployOrderClassLoaderUnitTestCase.java
Modified:
   projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/MockClassLoaderDependenciesUnitTestCase.java
Log:
Wrong undeploy info for classloader dependecies.

Added: projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/ClassLoaderDependenciesTest.java
===================================================================
--- projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/ClassLoaderDependenciesTest.java	                        (rev 0)
+++ projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/ClassLoaderDependenciesTest.java	2008-02-18 15:54:59 UTC (rev 69885)
@@ -0,0 +1,226 @@
+/*
+* JBoss, Home of Professional Open Source
+* Copyright 2006, 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.deployers.classloading.test;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.List;
+
+import org.jboss.classloader.plugins.system.DefaultClassLoaderSystem;
+import org.jboss.classloader.spi.ClassLoaderSystem;
+import org.jboss.classloader.spi.ParentPolicy;
+import org.jboss.deployers.client.spi.DeployerClient;
+import org.jboss.deployers.client.spi.Deployment;
+import org.jboss.deployers.plugins.classloading.AbstractClassLoaderDescribeDeployer;
+import org.jboss.deployers.plugins.classloading.ClassLoading;
+import org.jboss.deployers.spi.attachments.MutableAttachments;
+import org.jboss.deployers.spi.attachments.PredeterminedManagedObjectAttachments;
+import org.jboss.deployers.structure.spi.DeploymentUnit;
+import org.jboss.deployers.structure.spi.classloading.Capability;
+import org.jboss.deployers.structure.spi.classloading.ClassLoaderMetaData;
+import org.jboss.deployers.structure.spi.classloading.Requirement;
+import org.jboss.deployers.structure.spi.classloading.Version;
+import org.jboss.deployers.structure.spi.classloading.VersionRange;
+import org.jboss.deployers.structure.spi.classloading.helpers.ModuleCapabilityImpl;
+import org.jboss.deployers.structure.spi.classloading.helpers.PackageCapabilityImpl;
+import org.jboss.deployers.structure.spi.classloading.helpers.RequireModuleImpl;
+import org.jboss.deployers.structure.spi.classloading.helpers.RequirePackageImpl;
+import org.jboss.test.deployers.AbstractDeployerTest;
+import org.jboss.test.deployers.classloading.support.MockTopLevelClassLoaderSystemDeployer;
+
+/**
+ * ClassLoadersDependencies test.
+ *
+ * @author <a href="ales.justin at jboss.com">Ales Justin</a>
+ */
+public abstract class ClassLoaderDependenciesTest extends AbstractDeployerTest
+{
+   public static final String NameA = "A";
+   public static final String NameB = "B";
+
+   public static final List<String> NONE = Collections.emptyList();
+   public static final List<String> A = makeList(NameA);
+   public static final List<String> B = makeList(NameB);
+   public static final List<String> AB = makeList(NameA, NameB);
+   public static final List<String> BA = makeList(NameB, NameA);
+   public static final List<String> BAA = makeList(NameB, NameA, NameA);
+   public static final List<String> BABA = makeList(NameB, NameA, NameB, NameA);
+
+   @SuppressWarnings("unchecked")
+   protected static <T> List<T> makeList(T... objects)
+   {
+      List<T> result = new ArrayList<T>();
+      for (T object : objects)
+         result.add(object);
+      return result;
+   }
+
+   protected AbstractClassLoaderDescribeDeployer deployer1;
+   protected MockTopLevelClassLoaderSystemDeployer deployer2;
+
+   protected ClassLoaderDependenciesTest(String name)
+   {
+      super(name);
+   }
+
+   protected Class assertLoadClass(ClassLoader start, Class reference) throws Exception
+   {
+      return assertLoadClass(start, reference, start);
+   }
+
+   protected Class assertLoadClass(ClassLoader start, Class reference, ClassLoader expected) throws Exception
+   {
+      Class clazz = start.loadClass(reference.getName());
+      if (expected != null)
+         assertEquals(expected, clazz.getClassLoader());
+      return clazz;
+   }
+
+   protected void assertLoadClassFail(ClassLoader start, Class reference) throws Exception
+   {
+      try
+      {
+         start.loadClass(reference.getName());
+         fail("Should not be here!");
+      }
+      catch (Exception e)
+      {
+         checkThrowable(ClassNotFoundException.class, e);
+      }
+   }
+
+   protected void assertLoadClassIllegal(ClassLoader start, Class reference) throws Exception
+   {
+      try
+      {
+         start.loadClass(reference.getName());
+         fail("Should not be here!");
+      }
+      catch (Exception e)
+      {
+         checkThrowable(IllegalStateException.class, e);
+      }
+   }
+
+   protected void assertNoClassLoader(DeploymentUnit unit) throws Exception
+   {
+      try
+      {
+         unit.getClassLoader();
+         fail("Should not be here!");
+      }
+      catch (Exception e)
+      {
+         checkThrowable(IllegalStateException.class, e);
+      }
+   }
+
+   protected static ClassLoaderMetaData addClassLoaderMetaData(Deployment deployment, Version version, Class... packages)
+   {
+      return addClassLoaderMetaData(deployment, version, false, packages);
+   }
+
+   protected static ClassLoaderMetaData addClassLoaderMetaData(Deployment deployment, Version version, boolean useVersionOnPackages, Class... packages)
+   {
+      ClassLoaderMetaData classLoaderMetaData = createMetaData(deployment, version, useVersionOnPackages, packages);
+      addMetaData(deployment, classLoaderMetaData);
+      return classLoaderMetaData;
+   }
+
+   protected static ClassLoaderMetaData createMetaData(Deployment deployment, Version version, Class... packages)
+   {
+      return createMetaData(deployment, version, false, packages);
+   }
+
+   protected static ClassLoaderMetaData createMetaData(Deployment deployment, Version version, boolean useVersionOnPackages, Class... packages)
+   {
+      ClassLoaderMetaData classLoaderMetaData = new ClassLoaderMetaData();
+      classLoaderMetaData.setName(deployment.getName());
+
+      List<Capability> capabilities = new ArrayList<Capability>();
+      Capability capability = new ModuleCapabilityImpl(deployment.getName(), version);
+      capabilities.add(capability);
+
+      if (packages != null)
+      {
+         for (Class pkg : packages)
+         {
+            if (useVersionOnPackages)
+               capability = new PackageCapabilityImpl(pkg.getName(), version);
+            else
+               capability = new PackageCapabilityImpl(pkg.getName());
+            capabilities.add(capability);
+         }
+      }
+
+      classLoaderMetaData.setCapabilities(capabilities);
+      return classLoaderMetaData;
+   }
+
+   protected static void addRequireModule(ClassLoaderMetaData classLoaderMetaData, String moduleName, VersionRange versionRange)
+   {
+      List<Requirement> requirements = classLoaderMetaData.getRequirements();
+      if (requirements == null)
+      {
+         requirements = new ArrayList<Requirement>();
+         classLoaderMetaData.setRequirements(requirements);
+      }
+
+      Requirement requirement = new RequireModuleImpl(moduleName, versionRange);
+      requirements.add(requirement);
+   }
+
+   protected static void addRequirePackage(ClassLoaderMetaData classLoaderMetaData, Class pck, VersionRange versionRange)
+   {
+      List<Requirement> requirements = classLoaderMetaData.getRequirements();
+      if (requirements == null)
+      {
+         requirements = new ArrayList<Requirement>();
+         classLoaderMetaData.setRequirements(requirements);
+      }
+
+      Requirement requirement = new RequirePackageImpl(pck.getName(), versionRange);
+      requirements.add(requirement);
+   }
+
+   protected static void addMetaData(PredeterminedManagedObjectAttachments attachments, ClassLoaderMetaData md)
+   {
+      MutableAttachments mutable = (MutableAttachments) attachments.getPredeterminedManagedObjects();
+      mutable.addAttachment(ClassLoaderMetaData.class, md);
+   }
+
+   protected DeployerClient getMainDeployer()
+   {
+      ClassLoading classLoading = new ClassLoading();
+      ClassLoaderSystem system = new DefaultClassLoaderSystem();
+      system.getDefaultDomain().setParentPolicy(ParentPolicy.BEFORE_BUT_JAVA_ONLY);
+
+      deployer1 = new AbstractClassLoaderDescribeDeployer();
+      deployer1.setClassLoading(classLoading);
+
+      deployer2 = new MockTopLevelClassLoaderSystemDeployer();
+      deployer2.setClassLoading(classLoading);
+      deployer2.setSystem(system);
+
+      return createMainDeployer(deployer1, deployer2);
+   }
+}

Modified: projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/MockClassLoaderDependenciesUnitTestCase.java
===================================================================
--- projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/MockClassLoaderDependenciesUnitTestCase.java	2008-02-18 14:42:07 UTC (rev 69884)
+++ projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/MockClassLoaderDependenciesUnitTestCase.java	2008-02-18 15:54:59 UTC (rev 69885)
@@ -21,32 +21,12 @@
 */
 package org.jboss.test.deployers.classloading.test;
 
-import java.util.ArrayList;
-import java.util.Collections;
-import java.util.List;
-
 import junit.framework.Test;
 import junit.framework.TestSuite;
-import org.jboss.classloader.plugins.system.DefaultClassLoaderSystem;
-import org.jboss.classloader.spi.ClassLoaderSystem;
-import org.jboss.classloader.spi.ParentPolicy;
 import org.jboss.deployers.client.spi.DeployerClient;
 import org.jboss.deployers.client.spi.Deployment;
-import org.jboss.deployers.plugins.classloading.AbstractClassLoaderDescribeDeployer;
-import org.jboss.deployers.plugins.classloading.ClassLoading;
-import org.jboss.deployers.spi.attachments.MutableAttachments;
-import org.jboss.deployers.spi.attachments.PredeterminedManagedObjectAttachments;
 import org.jboss.deployers.structure.spi.DeploymentUnit;
-import org.jboss.deployers.structure.spi.classloading.Capability;
 import org.jboss.deployers.structure.spi.classloading.ClassLoaderMetaData;
-import org.jboss.deployers.structure.spi.classloading.Requirement;
-import org.jboss.deployers.structure.spi.classloading.Version;
-import org.jboss.deployers.structure.spi.classloading.VersionRange;
-import org.jboss.deployers.structure.spi.classloading.helpers.ModuleCapabilityImpl;
-import org.jboss.deployers.structure.spi.classloading.helpers.PackageCapabilityImpl;
-import org.jboss.deployers.structure.spi.classloading.helpers.RequireModuleImpl;
-import org.jboss.test.deployers.AbstractDeployerTest;
-import org.jboss.test.deployers.classloading.support.MockTopLevelClassLoaderSystemDeployer;
 import org.jboss.test.deployers.classloading.support.a.A;
 import org.jboss.test.deployers.classloading.support.b.B;
 
@@ -56,31 +36,8 @@
  * @author <a href="adrian at jboss.com">Adrian Brock</a>
  * @version $Revision: 1.1 $
  */
-public class MockClassLoaderDependenciesUnitTestCase extends AbstractDeployerTest
+public class MockClassLoaderDependenciesUnitTestCase extends ClassLoaderDependenciesTest
 {
-   public static final String NameA = "A";
-   public static final String NameB = "B";
-   
-   public static final List<String> NONE = Collections.emptyList();
-   public static final List<String> A = makeList(NameA);
-   public static final List<String> B = makeList(NameB);
-   public static final List<String> AB = makeList(NameA, NameB);
-   public static final List<String> BA = makeList(NameB, NameA);
-   public static final List<String> BAA = makeList(NameB, NameA, NameA);
-   public static final List<String> BABA = makeList(NameB, NameA, NameB, NameA);
-   
-   @SuppressWarnings("unchecked")
-   private static <T> List<T> makeList(T... objects)
-   {
-      List<T> result = new ArrayList<T>();
-      for (T object : objects)
-         result.add(object);
-      return result;
-   }
-   
-   private AbstractClassLoaderDescribeDeployer deployer1;
-   private MockTopLevelClassLoaderSystemDeployer deployer2;
-   
    public static Test suite()
    {
       return new TestSuite(MockClassLoaderDependenciesUnitTestCase.class);
@@ -96,7 +53,7 @@
       DeployerClient deployer = getMainDeployer();
 
       Deployment deployment = createSimpleDeployment(NameA);
-      addMetaData(deployment, null, A.class);
+      addClassLoaderMetaData(deployment, null, A.class);
       
       DeploymentUnit unit = assertDeploy(deployer, deployment);
 
@@ -119,7 +76,7 @@
       DeployerClient deployer = getMainDeployer();
 
       Deployment deploymentB = createSimpleDeployment(NameB);
-      addMetaData(deploymentB, null, B.class);
+      addClassLoaderMetaData(deploymentB, null, B.class);
       DeploymentUnit unitB = assertDeploy(deployer, deploymentB);
       
       ClassLoader clB = unitB.getClassLoader();
@@ -129,7 +86,7 @@
       assertEquals(NONE, deployer2.undeployed);
 
       Deployment deploymentA = createSimpleDeployment(NameA);
-      ClassLoaderMetaData classLoaderMetaData = addMetaData(deploymentA, null, A.class);
+      ClassLoaderMetaData classLoaderMetaData = addClassLoaderMetaData(deploymentA, null, A.class);
       addRequireModule(classLoaderMetaData, "B", null);
       DeploymentUnit unitA = assertDeploy(deployer, deploymentA);
       
@@ -157,7 +114,7 @@
       DeployerClient deployer = getMainDeployer();
 
       Deployment deploymentA = createSimpleDeployment(NameA);
-      ClassLoaderMetaData classLoaderMetaData = addMetaData(deploymentA, null, A.class);
+      ClassLoaderMetaData classLoaderMetaData = addClassLoaderMetaData(deploymentA, null, A.class);
       addRequireModule(classLoaderMetaData, "B", null);
       DeploymentUnit unitA = addDeployment(deployer, deploymentA);
       
@@ -167,7 +124,7 @@
       assertEquals(NONE, deployer2.undeployed);
 
       Deployment deploymentB = createSimpleDeployment(NameB);
-      addMetaData(deploymentB, null, B.class);
+      addClassLoaderMetaData(deploymentB, null, B.class);
       DeploymentUnit unitB = assertDeploy(deployer, deploymentB);
       
       ClassLoader clB = unitB.getClassLoader();
@@ -197,7 +154,7 @@
       DeployerClient deployer = getMainDeployer();
 
       Deployment deploymentA = createSimpleDeployment(NameA);
-      ClassLoaderMetaData classLoaderMetaData = addMetaData(deploymentA, null, A.class);
+      ClassLoaderMetaData classLoaderMetaData = addClassLoaderMetaData(deploymentA, null, A.class);
       addRequireModule(classLoaderMetaData, "B", null);
       DeploymentUnit unitA = addDeployment(deployer, deploymentA);
       
@@ -207,7 +164,7 @@
       assertEquals(NONE, deployer2.undeployed);
 
       Deployment deploymentB = createSimpleDeployment(NameB);
-      addMetaData(deploymentB, null, B.class);
+      addClassLoaderMetaData(deploymentB, null, B.class);
       DeploymentUnit unitB = assertDeploy(deployer, deploymentB);
       
       ClassLoader clB = unitB.getClassLoader();
@@ -238,7 +195,7 @@
       DeployerClient deployer = getMainDeployer();
 
       Deployment deploymentA = createSimpleDeployment(NameA);
-      ClassLoaderMetaData classLoaderMetaData = addMetaData(deploymentA, null, A.class);
+      ClassLoaderMetaData classLoaderMetaData = addClassLoaderMetaData(deploymentA, null, A.class);
       addRequireModule(classLoaderMetaData, "B", null);
       DeploymentUnit unitA = addDeployment(deployer, deploymentA);
       
@@ -248,7 +205,7 @@
       assertEquals(NONE, deployer2.undeployed);
 
       Deployment deploymentB = createSimpleDeployment(NameB);
-      addMetaData(deploymentB, null, B.class);
+      addClassLoaderMetaData(deploymentB, null, B.class);
       DeploymentUnit unitB = assertDeploy(deployer, deploymentB);
       
       ClassLoader clB = unitB.getClassLoader();
@@ -276,120 +233,4 @@
       assertEquals(BABA, deployer2.deployed);
       assertEquals(AB, deployer2.undeployed);
    }
-
-   protected Class assertLoadClass(ClassLoader start, Class reference) throws Exception
-   {
-      return assertLoadClass(start, reference, start);
-   }
-
-   protected Class assertLoadClass(ClassLoader start, Class reference, ClassLoader expected) throws Exception
-   {
-      Class clazz = start.loadClass(reference.getName());
-      if (expected != null)
-         assertEquals(expected, clazz.getClassLoader());
-      return clazz;
-   }
-
-   protected void assertLoadClassFail(ClassLoader start, Class reference) throws Exception
-   {
-      try
-      {
-         start.loadClass(reference.getName());
-         fail("Should not be here!");
-      }
-      catch (Exception e)
-      {
-         checkThrowable(ClassNotFoundException.class, e);
-      }
-   }
-
-   protected void assertLoadClassIllegal(ClassLoader start, Class reference) throws Exception
-   {
-      try
-      {
-         start.loadClass(reference.getName());
-         fail("Should not be here!");
-      }
-      catch (Exception e)
-      {
-         checkThrowable(IllegalStateException.class, e);
-      }
-   }
-
-   protected void assertNoClassLoader(DeploymentUnit unit) throws Exception
-   {
-      try
-      {
-         unit.getClassLoader();
-         fail("Should not be here!");
-      }
-      catch (Exception e)
-      {
-         checkThrowable(IllegalStateException.class, e);
-      }
-   }
-   
-   protected static ClassLoaderMetaData addMetaData(Deployment deployment, Version version, Class... packages)
-   {
-      ClassLoaderMetaData classLoaderMetaData = createMetaData(deployment, version, packages);
-      addMetaData(deployment, classLoaderMetaData);
-      return classLoaderMetaData;
-   }
-   
-   protected static ClassLoaderMetaData createMetaData(Deployment deployment, Version version, Class... packages)
-   {
-      ClassLoaderMetaData classLoaderMetaData = new ClassLoaderMetaData();
-      classLoaderMetaData.setName(deployment.getName());
-      
-      List<Capability> capabilities = new ArrayList<Capability>();
-      Capability capability = new ModuleCapabilityImpl(deployment.getName(), version);
-      capabilities.add(capability);
-
-      if (packages != null)
-      {
-         for (Class pkg : packages)
-         {
-            capability = new PackageCapabilityImpl(pkg.getName());
-            capabilities.add(capability);
-         }
-      }
-
-      classLoaderMetaData.setCapabilities(capabilities);
-      return classLoaderMetaData;
-   }
-   
-   protected static void addRequireModule(ClassLoaderMetaData classLoaderMetaData, String moduleName, VersionRange versionRange)
-   {
-      List<Requirement> requirements = classLoaderMetaData.getRequirements();
-      if (requirements == null)
-      {
-         requirements = new ArrayList<Requirement>();
-         classLoaderMetaData.setRequirements(requirements);
-      }
-      
-      Requirement requirement = new RequireModuleImpl(moduleName, versionRange);
-      requirements.add(requirement);
-   }
-
-   protected static void addMetaData(PredeterminedManagedObjectAttachments attachments, ClassLoaderMetaData md)
-   {
-      MutableAttachments mutable = (MutableAttachments) attachments.getPredeterminedManagedObjects();
-      mutable.addAttachment(ClassLoaderMetaData.class, md);
-   }
-   
-   protected DeployerClient getMainDeployer()
-   {
-      ClassLoading classLoading = new ClassLoading();
-      ClassLoaderSystem system = new DefaultClassLoaderSystem();
-      system.getDefaultDomain().setParentPolicy(ParentPolicy.BEFORE_BUT_JAVA_ONLY);
-      
-      deployer1 = new AbstractClassLoaderDescribeDeployer();
-      deployer1.setClassLoading(classLoading);
-      
-      deployer2 = new MockTopLevelClassLoaderSystemDeployer();
-      deployer2.setClassLoading(classLoading);
-      deployer2.setSystem(system);
-
-      return createMainDeployer(deployer1, deployer2);
-   }
 }

Added: projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/UndeployOrderClassLoaderUnitTestCase.java
===================================================================
--- projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/UndeployOrderClassLoaderUnitTestCase.java	                        (rev 0)
+++ projects/microcontainer/trunk/deployers-impl/src/tests/org/jboss/test/deployers/classloading/test/UndeployOrderClassLoaderUnitTestCase.java	2008-02-18 15:54:59 UTC (rev 69885)
@@ -0,0 +1,84 @@
+/*
+* JBoss, Home of Professional Open Source
+* Copyright 2006, 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.deployers.classloading.test;
+
+import junit.framework.Test;
+import org.jboss.deployers.client.spi.DeployerClient;
+import org.jboss.deployers.client.spi.Deployment;
+import org.jboss.deployers.spi.DeploymentException;
+import org.jboss.deployers.structure.spi.classloading.ClassLoaderMetaData;
+import org.jboss.deployers.structure.spi.classloading.VersionRange;
+import org.jboss.deployers.structure.spi.classloading.helpers.VersionImpl;
+import org.jboss.test.deployers.classloading.support.a.A;
+import org.jboss.test.deployers.classloading.support.b.B;
+
+/**
+ * Undeploy order test case.
+ *
+ * @author <a href="mailto:ales.justin at jboss.com">Ales Justin</a>
+ */
+public class UndeployOrderClassLoaderUnitTestCase extends ClassLoaderDependenciesTest
+{
+   public UndeployOrderClassLoaderUnitTestCase(String name)
+   {
+      super(name);
+   }
+
+   public static Test suite()
+   {
+      return suite(UndeployOrderClassLoaderUnitTestCase.class);
+   }
+
+   public void testUndeployOrder() throws Exception
+   {
+      DeployerClient mainDeployer = getMainDeployer();
+      VersionImpl v1 = VersionImpl.parseVersion("1");
+      VersionImpl v2 = VersionImpl.parseVersion("2");
+
+      Deployment ad = createSimpleDeployment("A");
+      addClassLoaderMetaData(ad, v1, true, A.class);
+      assertDeploy(mainDeployer, ad);
+
+      Deployment bd = createSimpleDeployment("B");
+      addClassLoaderMetaData(bd, v2, true, B.class);
+      assertDeploy(mainDeployer, bd);
+      mainDeployer.checkComplete(bd);
+
+      Deployment cd = createSimpleDeployment("C");
+      ClassLoaderMetaData clmd = addClassLoaderMetaData(cd, null);
+      addRequirePackage(clmd, A.class, new VersionRange(v1, true, v2, true));
+      addRequirePackage(clmd, B.class, new VersionRange(v1, true, v2, true));
+      assertDeploy(mainDeployer, cd);
+
+      mainDeployer.checkComplete();
+
+      mainDeployer.undeploy(bd);
+      try
+      {
+         mainDeployer.checkComplete();
+      }
+      catch (DeploymentException e)
+      {
+         e.printStackTrace();
+      }
+   }
+}




More information about the jboss-cvs-commits mailing list