beehive-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Rich Feit (JIRA)" <beehive-...@incubator.apache.org>
Subject [jira] Resolved: (BEEHIVE-779) ScopedRequestImpl.restoreAttributes() should not point the ScopedAttributeContainer at the Session's stored attribute HashMap instance
Date Tue, 07 Jun 2005 19:36:40 GMT
     [ http://issues.apache.org/jira/browse/BEEHIVE-779?page=all ]
     
Rich Feit resolved BEEHIVE-779:
-------------------------------

    Resolution: Fixed

Applied the patch with revision 188851.  Thanks!

> ScopedRequestImpl.restoreAttributes() should not point the ScopedAttributeContainer at
the Session's stored attribute HashMap instance
> --------------------------------------------------------------------------------------------------------------------------------------
>
>          Key: BEEHIVE-779
>          URL: http://issues.apache.org/jira/browse/BEEHIVE-779
>      Project: Beehive
>         Type: Bug
>     Versions: V1
>     Reporter: Carlin Rogers
>     Assignee: Rich Feit
>      Fix For: TBD
>  Attachments: j779patch.txt
>
> Currently the ScopedRequestImpl.restoreAttributes() assigns the 
> ScopedAttributeContainer with the Session's stored attribute HashMap instance.
> If there are multiple requests to the server in very fast succession, 
> this will cause the use of the HashMap iterator to throw a
> ConcurrentModificationException.
> The problem is that during both restoreAttributes() and persistAttributes()
> we are updating the session's instance of a HashMap. At the same time,
> in persisAttributes() the call to the ScopedAttributeContainer's
> getSerializableAttrs() uses the HashMap instance iterator 
> (HashMap.HashIterator). If between calls to next() for the next 
> MapEntry, and the number of elements in the Map gets altered,
> we get the ConcurrentModificationException...
> java.util.ConcurrentModificationException
>     at java.util.HashMap$HashIterator.nextEntry()Ljava.util.HashMap$Entry;(Unknown Source)
>     at java.util.HashMap$EntryIterator.next()Ljava.util.Map$Entry;(Unknown Source)
>     at java.util.HashMap$EntryIterator.next()Ljava.lang.Object;(Unknown Source)
>     at org.apache.beehive.netui.pageflow.scoping.internal.AttributeContainer.getSerializableAttrs(AttributeContainer.java:91)
>     at org.apache.beehive.netui.pageflow.scoping.internal.ScopedRequestImpl.persistAttributes(ScopedRequestImpl.java:444)
> I will take this one and submit a patch for the committers.

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


Mime
View raw message