Steve fix NoCdiAvailableTest

This commit is contained in:
Andrea Boriero 2016-05-06 18:58:08 +01:00 committed by Steve Ebersole
parent a6af7c6f74
commit 69c8ef29a8
1 changed files with 2 additions and 28 deletions

View File

@ -45,7 +45,7 @@ public class NoCdiAvailableTest extends BaseUnitTestCase {
@Override @Override
public ClassLoader buildIsolatedClassLoader() { public ClassLoader buildIsolatedClassLoader() {
return new ClassLoader(NoCdiAvailableTest.class.getClassLoader()) { return new ClassLoader( NoCdiAvailableTest.class.getClassLoader() ) {
@Override @Override
public Class<?> loadClass(String name) throws ClassNotFoundException { public Class<?> loadClass(String name) throws ClassNotFoundException {
for ( String excludedPackage : EXCLUDED_PACKAGES ) { for ( String excludedPackage : EXCLUDED_PACKAGES ) {
@ -53,33 +53,7 @@ public class NoCdiAvailableTest extends BaseUnitTestCase {
throw new CdiClassLoadException( "CDI classes [" + name + "] excluded from load" ); throw new CdiClassLoadException( "CDI classes [" + name + "] excluded from load" );
} }
} }
return super.loadClass( name );
Class c = findLoadedClass( name );
if ( c != null ) {
return c;
}
final String resourceName = name.replace( '.', '/' ) + ".class";
final URL resource = getResource( resourceName );
if ( resource == null ) {
throw new ClassNotFoundException( name + " not found" );
}
if ( !"file".equals( resource.getProtocol() ) ) {
return getParent().loadClass( name );
}
InputStream is = this.getResourceAsStream( name.replace( '.', '/' ) + ".class" );
if ( is == null ) {
throw new ClassNotFoundException( name + " not found" );
}
try {
byte[] bytecode = ByteCodeHelper.readByteCode( is );
return defineClass( name, bytecode, 0, bytecode.length );
}
catch( Throwable t ) {
throw new ClassNotFoundException( "Error reading class file for " + name, t );
}
} }
}; };
} }