[weld-issues] [JBoss JIRA] Updated: (WELD-865) Weld allows for concurrent call to conversation

George Sapountzis (JIRA) jira-events at lists.jboss.org
Wed Apr 13 18:51:33 EDT 2011


     [ https://issues.jboss.org/browse/WELD-865?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

George Sapountzis updated WELD-865:
-----------------------------------

    Attachment: untested-test-failure-condition-first.patch


What about locking first (i.e. testing the failure condition) and then deciding which conversation to activate ?

The attached patch does this but is untested, the naming could be better or we could call activateRequest() from WeldPhaseListener ...

> Weld allows for concurrent call to conversation
> -----------------------------------------------
>
>                 Key: WELD-865
>                 URL: https://issues.jboss.org/browse/WELD-865
>             Project: Weld
>          Issue Type: Bug
>          Components: Scopes & Contexts, Web Tier integration (JSF, JSP, EL and Servlet) 
>    Affects Versions: 1.1.0.Final
>            Reporter: George Sapountzis
>            Assignee: Ales Justin
>             Fix For: 1.2.0.Beta1
>
>         Attachments: untested-test-failure-condition-first.patch
>
>
> Concurrent calls to a @ConversationScoped component:
> Thread 1:
> AbstractConversationContext.activate(String cid)
> ConversationImpl.lock(long timeout) <-- returns true
> correctly proceed inside method
> Thread 2:
> AbstractConversationContext.activate(String cid)
> ConversationImpl.lock(long timeout) <-- returns false but activate() does not check result !!!
> *incorrectly* proceed inside method
> ----
> I think AbstractConversationContext.activate(String cid) should check the result of ConversationImpl.lock(long timeout) and not allow the second thread to proceed.

--
This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira


More information about the weld-issues mailing list