[hibernate-issues] [Hibernate-JIRA] Resolved: (HHH-3847) java.lang.NullPointerException on onPreRemoveCollection on replicate of persistent class
Adam Warski (JIRA)
noreply at atlassian.com
Sun May 31 09:03:16 EDT 2009
[ http://opensource.atlassian.com/projects/hibernate/browse/HHH-3847?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Adam Warski resolved HHH-3847.
------------------------------
Resolution: Fixed
Fix Version/s: 3.5
> java.lang.NullPointerException on onPreRemoveCollection on replicate of persistent class
> ----------------------------------------------------------------------------------------
>
> Key: HHH-3847
> URL: http://opensource.atlassian.com/projects/hibernate/browse/HHH-3847
> Project: Hibernate Core
> Issue Type: Bug
> Components: envers
> Affects Versions: 3.3.1
> Environment: Envers 1.2, Hibernate 3.3.1 on Mysql and Hsql.
> Reporter: Francesco Di Salvatore
> Assignee: Adam Warski
> Priority: Critical
> Fix For: 3.5
>
> Attachments: HHH-3847patch.txt, TestEnvers12.zip
>
>
> I get this exception when trying to REPLICATE an object in a synchronized database:
> Code:
> DEBUG [main] (CodeSystemDAOHibernate.java:131) - java.lang.NullPointerException
> at org.hibernate.envers.event.AuditEventListener.onPreRemoveCollection(AuditEventListener.java:235)
> at org.hibernate.action.CollectionRemoveAction.preRemove(CollectionRemoveAction.java:134)
> at org.hibernate.action.CollectionRemoveAction.execute(CollectionRemoveAction.java:100)
> at org.hibernate.engine.ActionQueue.execute(ActionQueue.java:279)
> at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:263)
> at org.hibernate.engine.ActionQueue.executeActions(ActionQueue.java:169)
> at org.hibernate.event.def.AbstractFlushingEventListener.performExecutions(AbstractFlushingEventLis
> tener.java:321)
> at org.hibernate.event.def.DefaultFlushEventListener.onFlush(DefaultFlushEventListener.java:50)
> at org.hibernate.impl.SessionImpl.flush(SessionImpl.java:1027)
> at org.hibernate.impl.SessionImpl.managedFlush(SessionImpl.java:365)
> at org.hibernate.transaction.JDBCTransaction.commit(JDBCTransaction.java:137)
>
> at com.phi.dictionarymanager.logic.hibernate.GenericDAOHibaernate.commitNetwork(GenericDAOHibaernate
> .java:183)
> at com.phi.dictionarymanager.logic.hibernate.CodeSystemDAOHibernate.save(CodeSystemDAOHibernate.jav
> a:92)
> at com.phi.dictionarymanager.ui.widgets.VocabolaryItemNewComposite.save(VocabolaryItemNewComposite.
> java:515)
> at com.phi.dictionarymanager.ui.widgets.VocabularyDomainsNavigatorComposite$18.handleEvent(Vocabula
> ryDomainsNavigatorComposite.java:1434)
> at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:66)
> at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:938)
> at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3682)
> at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3293)
> at org.eclipse.ui.internal.Workbench.runEventLoop(Workbench.java:2389)
> at org.eclipse.ui.internal.Workbench.runUI(Workbench.java:2353)
> at org.eclipse.ui.internal.Workbench.access$4(Workbench.java:2219)
> at org.eclipse.ui.internal.Workbench$4.run(Workbench.java:466)
> at org.eclipse.core.databinding.observable.Realm.runWithDefault(Realm.java:289)
> at org.eclipse.ui.internal.Workbench.createAndRunWorkbench(Workbench.java:461)
> at org.eclipse.ui.PlatformUI.createAndRunWorkbench(PlatformUI.java:149)
> at org.eclipse.ui.internal.ide.application.IDEApplication.start(IDEApplication.java:106)
> at org.eclipse.equinox.internal.app.EclipseAppHandle.run(EclipseAppHandle.java:169)
> at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.runApplication(EclipseAppLauncher.j
> ava:106)
> at org.eclipse.core.runtime.internal.adaptor.EclipseAppLauncher.start(EclipseAppLauncher.java:76)
> at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:363)
> at org.eclipse.core.runtime.adaptor.EclipseStarter.run(EclipseStarter.java:176)
> at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
> at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
> at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
> at java.lang.reflect.Method.invoke(Unknown Source)
> at org.eclipse.equinox.launcher.Main.invokeFramework(Main.java:508)
> at org.eclipse.equinox.launcher.Main.basicRun(Main.java:447)
> at org.eclipse.equinox.launcher.Main.run(Main.java:1173)
> at org.eclipse.equinox.launcher.Main.main(Main.java:1148)
>
> Code throwing the exception:
> Code:
> beginTransactionLocal();
> makePersistentLocal(cs);
> commitLocal();
> closeSessionLocal();
>
> beginTransactionNetwork();
> makePersistentNetwork(cs);
> commitNetwork();
> closeSessionNetwork();
>
> For this insertion of the object cs, the makePersistentLocal makes a saveOrUpdate call, while makePersistentNetwork calls replicate(cs, ReplicateMode.LATEST_VERSION).
> My hibernate-mysql.cfg.xml and hibernate-hsql.cfg.xml are very similar (I post only the mysql one):
> Code:
> <hibernate-configuration>
> <session-factory>
> ...
> <property name="org.hibernate.envers.revisionOnCollectionChange">true</property>
> <property name="org.hibernate.envers.doNotAuditOptimisticLockingField">true</property>
>
>
> <!-- HIBERNATE BEAN MAPPINGS -->
> <mapping resource="com/phi/dictionarymanager/beans/CodeEquivalent.hbm.xml" />
> <mapping resource="com/phi/dictionarymanager/beans/CodeValue.hbm.xml" />
> <mapping resource="com/phi/dictionarymanager/beans/CodeTranslation.hbm.xml" />
> <mapping resource="com/phi/dictionarymanager/beans/CodeSystem.hbm.xml" />
>
>
> <event type="post-insert">
> <listener class="org.hibernate.envers.event.AuditEventListener" />
> </event>
> <event type="post-update">
> <listener class="org.hibernate.envers.event.AuditEventListener" />
> </event>
> <event type="post-delete">
> <listener class="org.hibernate.envers.event.AuditEventListener" />
> </event>
> <event type="pre-collection-update">
> <listener class="org.hibernate.envers.event.AuditEventListener" />
> </event>
> <event type="pre-collection-remove">
> <listener class="org.hibernate.envers.event.AuditEventListener" />
> </event>
> <event type="post-collection-recreate">
> <listener class="org.hibernate.envers.event.AuditEventListener" />
> </event>
>
>
> </session-factory>
> </hibernate-configuration>
> All the collections in this project are in mode lazy="true".
> In the first saving the onPreRemoveCollection method is never called.
--
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