HHH-4666 - Implement the clarified rules for resource discovery (esp for <mapping-file> and co)

Refactored packaged tests while investigating this issue. Made sure packages get created in a subdirectory of target


git-svn-id: https://svn.jboss.org/repos/hibernate/core/trunk@18918 1b8cb986-b30d-0410-93ca-fae66ebed9b2
This commit is contained in:
Hardy Ferentschik 2010-03-02 23:11:41 +00:00
parent b763122d4c
commit 6dce44c363
2 changed files with 16 additions and 4 deletions

View File

@ -4,7 +4,7 @@
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd"
version="2.0"> version="2.0">
<persistence-unit name="manager1" transaction-type="RESOURCE_LOCAL"> <persistence-unit name="manager1" transaction-type="RESOURCE_LOCAL">
<jar-file>${basedir}/target/externaljar.jar</jar-file> <jar-file>${basedir}/target/packages/externaljar.jar</jar-file>
<class>org.hibernate.ejb.test.Cat</class> <class>org.hibernate.ejb.test.Cat</class>
<class>org.hibernate.ejb.test.Kitten</class> <class>org.hibernate.ejb.test.Kitten</class>
<class>org.hibernate.ejb.test.Distributor</class> <class>org.hibernate.ejb.test.Distributor</class>

View File

@ -1,4 +1,4 @@
// $Id:$ // $Id$
/* /*
* JBoss, Home of Professional Open Source * JBoss, Home of Professional Open Source
* Copyright 2009, Red Hat, Inc. and/or its affiliates, and individual contributors * Copyright 2009, Red Hat, Inc. and/or its affiliates, and individual contributors
@ -22,6 +22,7 @@ import java.net.MalformedURLException;
import java.net.URL; import java.net.URL;
import java.net.URLClassLoader; import java.net.URLClassLoader;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays;
import java.util.List; import java.util.List;
import junit.framework.TestCase; import junit.framework.TestCase;
@ -89,6 +90,8 @@ public abstract class PackagingTestCase extends TestCase {
catch ( MalformedURLException e ) { catch ( MalformedURLException e ) {
fail( "Unable to build custom class loader" ); fail( "Unable to build custom class loader" );
} }
targetDir = new File( targetDir, "packages" );
targetDir.mkdirs();
} }
@Override @Override
@ -105,9 +108,9 @@ public abstract class PackagingTestCase extends TestCase {
Thread.currentThread().setContextClassLoader( originalClassLoader ); Thread.currentThread().setContextClassLoader( originalClassLoader );
} }
protected void addPackageToClasspath(File... testPackages) throws MalformedURLException { protected void addPackageToClasspath(File... files) throws MalformedURLException {
List<URL> urlList = new ArrayList<URL>(); List<URL> urlList = new ArrayList<URL>();
for ( File file : testPackages ) { for ( File file : files ) {
urlList.add( file.toURL() ); urlList.add( file.toURL() );
} }
URLClassLoader classLoader = new URLClassLoader( URLClassLoader classLoader = new URLClassLoader(
@ -116,6 +119,15 @@ public abstract class PackagingTestCase extends TestCase {
Thread.currentThread().setContextClassLoader( classLoader ); Thread.currentThread().setContextClassLoader( classLoader );
} }
protected void addPackageToClasspath(URL... urls) throws MalformedURLException {
List<URL> urlList = new ArrayList<URL>();
urlList.addAll( Arrays.asList( urls ) );
URLClassLoader classLoader = new URLClassLoader(
urlList.toArray( new URL[urlList.size()] ), originalClassLoader
);
Thread.currentThread().setContextClassLoader( classLoader );
}
protected File buildDefaultPar() { protected File buildDefaultPar() {
String fileName = "defaultpar.par"; String fileName = "defaultpar.par";
JavaArchive archive = Archives.create( fileName, JavaArchive.class ); JavaArchive archive = Archives.create( fileName, JavaArchive.class );