[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