[hibernate-issues] [Hibernate-JIRA] Commented: (EJB-242) Be more defensive regarding exotic (aka buggy) URL protocol handler

Michał Kostrzewa (JIRA) noreply at atlassian.com
Wed Feb 21 16:27:32 EST 2007


    [ http://opensource.atlassian.com/projects/hibernate/browse/EJB-242?page=comments#action_26209 ] 

Michał Kostrzewa commented on EJB-242:
--------------------------------------

I'm not sure how (if) the latest suggestion will work in Java Web Start environment, all the plugins need to be packed here... What do you think?
About test case - I'll try to prepare one, but it may take a while to do suitable and minimal test case, please don't hold your breath... :(


> Be more defensive regarding exotic (aka buggy) URL protocol handler
> -------------------------------------------------------------------
>
>          Key: EJB-242
>          URL: http://opensource.atlassian.com/projects/hibernate/browse/EJB-242
>      Project: Hibernate Entity Manager
>         Type: Improvement

>   Components: EntityManager
>     Versions: 3.2.0.ga
>  Environment: Hibernate 3.2.0 GA, postgres (but I guess not relevant here)
>     Reporter: Michał Kostrzewa
>     Assignee: Emmanuel Bernard
>      Fix For: 3.2.2

>
>
> Hi, 
> Max from user list kindly redirected me to fill a bug here. Here it goes as I described it on list. I didn't attached a test case b/c doing it is non-trivial, maybe you'll just know what is the problem and I provided a patch that works for me. But if test case is needed - I'll do it.
> --------------
> I'm having problems with bundling hibernate and my ejb model in eclipse RCP application. I managed to solve all classloading problems but one, related to InputStreamZippedJarVisitor class. 
> Simplifying things I have: 
> hibernate plugin which registers itself for buddy classloading policy 
> dbmodel plugin which depends on hibernate and is a buddy of hibernate 
> application plugin which depends on hibernate and dbmodel and is a buddy of hibernate. This application plugin has hibernate.cfg.xml in self. 
> When I run this project from eclipse IDE, all is fine except the warning message in logs while creating EntityManager: 
> 2006-10-20 09:07:23 org.hibernate.ejb.packaging.InputStreamZippedJarVisitor doProcessElements 
> WARNING: Unable to find file (ignored): bundleresource://101 
> java.io.FileNotFoundException: C:\Documents and Settings\mkostrze\sv-head2\com.pentacomp.dbmodel (Access denied) 
>    at java.io.FileInputStream.open(Native Method) 
>    at java.io.FileInputStream.<init>(FileInputStream.java:106) 
>    at org.eclipse.osgi.framework.util.SecureAction.getFileInputStream(SecureAction.java:99) 
>    at org.eclipse.osgi.baseadaptor.bundlefile.FileBundleEntry.getInputStream(FileBundleEntry.java:50) 
>    at org.eclipse.osgi.framework.internal.core.BundleURLConnection.connect(BundleURLConnection.java:53) 
>    at org.eclipse.osgi.framework.internal.core.BundleURLConnection.getInputStream(BundleURLConnection.java:99) 
>    at java.net.URL.openStream(URL.java:1007) 
>    at org.hibernate.ejb.packaging.InputStreamZippedJarVisitor.doProcessElements(InputStreamZippedJarVisitor.java:33) 
>    at org.hibernate.ejb.packaging.JarVisitor.getMatchingEntries(JarVisitor.java:215) 
>    at org.hibernate.ejb.Ejb3Configuration.addMetadataFromVisitor(Ejb3Configuration.java:253) 
>    at org.hibernate.ejb.Ejb3Configuration.configure(Ejb3Configuration.java:229) 
>    at org.hibernate.ejb.HibernatePersistence.createEntityManagerFactory(HibernatePersistence.java:120) 
>    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:51) 
>    at com.pentacomp.dicom.viewer.ViewerContstants.createEntityManager(ViewerContstants.java:170) 
>    at com.pentacomp.dicom.viewer.DicomViewerMainFrame$InitRepositoriesTask.call(DicomViewerMainFrame.java:146) 
> I suppose hibernate tries to inspect the model jar for some reason, but in IDE this jar location is resolved to directory containing the plugin. 
> But things get worse when I export the project into java webstart application. I'm getting NullPointerException instead of warning in the same place. I investigated the source and the problem is here: 
> protected void doProcessElements() throws IOException { 
>       JarInputStream jis; 
>       try { 
>          jis = new JarInputStream( jarUrl.openStream() ); 
>       } 
>     catch (IOException ze) { 
>          log.warn( "Unable to find file (ignored): " + jarUrl, ze ); 
>          return; 
>       } 
>  
> The jarUrl is a bundleresource:// url which resolves to DirZipBundleEntry which in turn returns null in getInputStream(). Thus JarInputStream thows NPE. 
> Here's what I've tried to solve this: 
> - configure the dbmodel to be unpacked or packed after install 
> - tried dbmodel with jar inside or with unpacked classes inside 
> - set hibernate.archive.autodetection to 'none'. (I did it passing parameters map to createEntityManager method) 
> - change the hibernate sources and replace IOException with Exception in doProcessElement method. This one worked 
> I guess most likely I did something wrong to my deploy - any ideas please? But if not, perhaps such a change in code may make hibernate more robust (?) 
> Hibernate version: 3.2.0 GA 
> best regards, 
> Michal Kostrzewa

-- 
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators:
   http://opensource.atlassian.com/projects/hibernate/secure/Administrators.jspa
-
For more information on JIRA, see:
   http://www.atlassian.com/software/jira





More information about the hibernate-issues mailing list