|
From: Fabio M. (JIRA) <nh...@gm...> - 2011-05-17 23:08:48
|
[ http://216.121.112.228/browse/NH-1845?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]
Fabio Maulo closed NH-1845.
---------------------------
Resolution: Cannot Reproduce
The test is on trunk and does not fails even without apply the patch.
Thanks for the effort.
> StatefulPersistenceContext.RemoveEntity KeyNotFoundException on Evict
> ---------------------------------------------------------------------
>
> Key: NH-1845
> URL: http://216.121.112.228/browse/NH-1845
> Project: NHibernate
> Issue Type: Bug
> Components: Core
> Affects Versions: 2.0.1.GA
> Reporter: David Cowan
>
> In entities with parent/child relationships calling Evict can cause KeyNotFoundException's in StatefulPersistenceContext.RemoveEntity
> Stack trace is below. Also see this forum post
> https://forum.hibernate.org/viewtopic.php?f=25&t=993443&view=previous
> System.Collections.Generic.KeyNotFoundException: The given key was not present in the dictionary.
> at System.ThrowHelper.ThrowKeyNotFoundException()
> at System.Collections.Generic.Dictionary`2.get_Item(TKey key)
> at NHibernate.Engine.StatefulPersistenceContext.RemoveEntity(EntityKey key)
> at NHibernate.Event.Default.DefaultEvictEventListener.OnEvict(EvictEvent event)
> at NHibernate.Impl.SessionImpl.FireEvict(EvictEvent evictEvent)
> at NHibernate.Impl.SessionImpl.Evict(Object obj)
> at NHibernate.Engine.CascadingAction.EvictCascadingAction.Cascade(IEventSource session, Object child, String entityName, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeToOne(Object child, IType type, CascadeStyle style, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeAssociation(Object child, IType type, CascadeStyle style, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeProperty(Object child, IType type, CascadeStyle style, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeOn(IEntityPersister persister, Object parent, Object anything)
> at NHibernate.Event.Default.DefaultEvictEventListener.DoEvict(Object obj, EntityKey key, IEntityPersister persister, IEventSource session)
> at NHibernate.Event.Default.DefaultEvictEventListener.OnEvict(EvictEvent event)
> at NHibernate.Impl.SessionImpl.FireEvict(EvictEvent evictEvent)
> at NHibernate.Impl.SessionImpl.Evict(Object obj)
> at NHibernate.Engine.CascadingAction.EvictCascadingAction.Cascade(IEventSource session, Object child, String entityName, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeToOne(Object child, IType type, CascadeStyle style, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeAssociation(Object child, IType type, CascadeStyle style, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeProperty(Object child, IType type, CascadeStyle style, Object anything, Boolean isCascadeDeleteEnabled)
> at NHibernate.Engine.Cascade.CascadeOn(IEntityPersister persister, Object parent, Object anything)
> at NHibernate.Event.Default.DefaultEvictEventListener.DoEvict(Object obj, EntityKey key, IEntityPersister persister, IEventSource session)
> at NHibernate.Event.Default.DefaultEvictEventListener.OnEvict(EvictEvent event)
> at NHibernate.Impl.SessionImpl.FireEvict(EvictEvent evictEvent)
> at NHibernate.Impl.SessionImpl.Evict(Object obj)
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: http://216.121.112.228/secure/Administrators.jspa
-
For more information on JIRA, see: http://www.atlassian.com/software/jira
|