[jboss-cvs] JBossAS SVN: r101490 - in projects/jboss-cl/trunk: classloading/src/test/java/org/jboss/test/classloading/dependency/test and 1 other directory.
jboss-cvs-commits at lists.jboss.org
jboss-cvs-commits at lists.jboss.org
Thu Feb 25 13:02:24 EST 2010
Author: alesj
Date: 2010-02-25 13:02:23 -0500 (Thu, 25 Feb 2010)
New Revision: 101490
Modified:
projects/jboss-cl/trunk/classloading/src/test/java/org/jboss/test/classloading/dependency/test/HierarchicalDomainUnitTestCase.java
projects/jboss-cl/trunk/pom.xml
Log:
Add requirements + domain tests.
Use stable Kernel 2.2.0 release.
Modified: projects/jboss-cl/trunk/classloading/src/test/java/org/jboss/test/classloading/dependency/test/HierarchicalDomainUnitTestCase.java
===================================================================
--- projects/jboss-cl/trunk/classloading/src/test/java/org/jboss/test/classloading/dependency/test/HierarchicalDomainUnitTestCase.java 2010-02-25 17:45:59 UTC (rev 101489)
+++ projects/jboss-cl/trunk/classloading/src/test/java/org/jboss/test/classloading/dependency/test/HierarchicalDomainUnitTestCase.java 2010-02-25 18:02:23 UTC (rev 101490)
@@ -23,16 +23,22 @@
import junit.framework.Test;
+import org.jboss.classloader.spi.ClassLoaderDomain;
+import org.jboss.classloader.spi.ClassLoaderSystem;
+import org.jboss.classloading.spi.ClassLoadingDomain;
import org.jboss.classloading.spi.dependency.policy.mock.MockClassLoadingMetaData;
import org.jboss.classloading.spi.metadata.ClassLoadingMetaDataFactory;
+import org.jboss.classloading.spi.metadata.ExportAll;
import org.jboss.kernel.spi.dependency.KernelControllerContext;
import org.jboss.test.classloading.dependency.support.a.A;
import org.jboss.test.classloading.dependency.support.b.B;
+import org.jboss.test.classloading.dependency.support.c.C;
/**
* HierarchicalDomainUnitTestCase.
*
* @author <a href="adrian at jboss.com">Adrian Brock</a>
+ * @author <a href="ales.justin at jboss.org">Ales Justin</a>
* @version $Revision: 1.1 $
*/
public class HierarchicalDomainUnitTestCase extends AbstractMockClassLoaderUnitTest
@@ -467,4 +473,80 @@
}
assertNoClassLoader(contextB);
}
+
+ public void testExplicitRequirementsInDefaultDomain() throws Exception
+ {
+ testExplicitRequirementsInDomain(ClassLoaderSystem.DEFAULT_DOMAIN_NAME);
+ }
+
+ public void testExplicitRequirementsInNewDomain() throws Exception
+ {
+ // FIXME - testExplicitRequirementsInDomain("SomeNewDomain");
+ }
+
+ protected void testExplicitRequirementsInDomain(String domain) throws Exception
+ {
+ ClassLoadingMetaDataFactory factory = ClassLoadingMetaDataFactory.getInstance();
+ MockClassLoadingMetaData c = new MockClassLoadingMetaData("c");
+ c.setPathsAndPackageNames(C.class);
+ c.setImportAll(true);
+ c.setExportAll(ExportAll.NON_EMPTY);
+ KernelControllerContext contextC = install(c);
+ try
+ {
+ MockClassLoadingMetaData b = new MockClassLoadingMetaData("b");
+ b.setDomain(domain);
+ b.setPathsAndPackageNames(B.class);
+ b.getRequirements().addRequirement(factory.createRequirePackage(A.class.getPackage().getName()));
+ KernelControllerContext contextB = install(b);
+ try
+ {
+ assertNoClassLoader(contextB);
+
+ MockClassLoadingMetaData a = new MockClassLoadingMetaData("a");
+ a.setDomain(domain);
+ a.setPathsAndPackageNames(A.class);
+ a.getCapabilities().addCapability(factory.createPackage(A.class.getPackage().getName()));
+ KernelControllerContext contextA = install(a);
+ try
+ {
+ ClassLoader clA = assertClassLoader(contextA);
+ assertLoadClass(A.class, clA);
+ assertLoadClassFail(B.class, clA);
+
+ ClassLoader clB = assertClassLoader(contextB);
+ assertLoadClass(A.class, clA);
+ assertLoadClass(B.class, clB);
+
+ ClassLoader clC = assertClassLoader(contextC);
+ assertLoadClass(C.class, clC);
+ if (ClassLoaderSystem.DEFAULT_DOMAIN_NAME.equals(domain))
+ {
+ assertLoadClass(A.class, clC, clA);
+ assertLoadClass(B.class, clC, clB);
+ }
+ else
+ {
+ assertLoadClassFail(A.class, clC);
+ assertLoadClassFail(B.class, clC);
+ }
+
+ assertLoadClassFail(C.class.getName(), clB);
+ }
+ finally
+ {
+ uninstall(contextA);
+ }
+ }
+ finally
+ {
+ uninstall(contextB);
+ }
+ assertNoClassLoader(contextB);
+ }
+ finally
+ {
+ uninstall(contextC);
+ }
+ }
}
Modified: projects/jboss-cl/trunk/pom.xml
===================================================================
--- projects/jboss-cl/trunk/pom.xml 2010-02-25 17:45:59 UTC (rev 101489)
+++ projects/jboss-cl/trunk/pom.xml 2010-02-25 18:02:23 UTC (rev 101490)
@@ -33,7 +33,7 @@
<version.jboss.vfs>3.0.0.CR1</version.jboss.vfs>
<version.jboss.man>2.1.1.SP1</version.jboss.man>
<version.jboss.mdr>2.2.0.Alpha1</version.jboss.mdr>
- <version.jboss.kernel>2.2.0.Alpha3</version.jboss.kernel>
+ <version.jboss.kernel>2.2.0.Alpha6</version.jboss.kernel>
<version.jboss.common.core>2.2.17.GA</version.jboss.common.core>
<version.jboss.logging.spi>2.2.0.CR1</version.jboss.logging.spi>
<version.jboss.classloading.spi>6.0.0-Alpha8</version.jboss.classloading.spi>
More information about the jboss-cvs-commits
mailing list