[jbossseam-issues] [JBoss JIRA] Commented: (JBSEAM-3295) Major reentrancy problem with "Application Scope" components and injection/disinjection

Pete Muir (JIRA) jira-events at lists.jboss.org
Fri Aug 22 17:25:40 EDT 2008


    [ https://jira.jboss.org/jira/browse/JBSEAM-3295?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=12426293#action_12426293 ] 

Pete Muir commented on JBSEAM-3295:
-----------------------------------

Denis,

1) Yes, we will work on an optimized version for the branch and trunk - JBSEAM-3301 covers this. Main concern right now is releasing 2.1 beta1 ;-)

2) Correct, you *don't* want to outject if the invocation of the business method throws an exception but you do want to disinject - as ever, with exception processing, you want to halt when the exception is thrown, and do cleanup (disinjection).

Thanks for the help with this :-)

> Major reentrancy problem with "Application Scope" components and injection/disinjection
> ---------------------------------------------------------------------------------------
>
>                 Key: JBSEAM-3295
>                 URL: https://jira.jboss.org/jira/browse/JBSEAM-3295
>             Project: Seam
>          Issue Type: Bug
>          Components: Core
>    Affects Versions: 2.0.2.SP1
>         Environment: WebSphere v6.1.0.17 in POJO Mode
>            Reporter: Denis Forveille
>            Assignee: Pete Muir
>            Priority: Blocker
>             Fix For: 2.0.3.CR2, 2.1.0.BETA1
>
>         Attachments: BijectionInterceptor_Denis.java
>
>
> There is a major reentrancy problem with "Application Scope" components and injection/disinjection
> As in any component @In dependent object are injected/disinjected with  the BijectionInterceptor interceptor
> As there is one instance of BijectionInterceptor per Component (It seems), there is only one instance of BijectionInterceptor in the JVM for an Application Scope Component, instance shared by all threads
> With that in mind, take:
> - 2 running thread (T1, T2)
> - One application scope component (C1) with many at In attributes (All referecing Application Scope components too..)
> T1 enters method M1 of C1. BijectionInterceptor  inject @In depedencies of C1, and set the "reentrant" attribute of the instance of BijectionInterceptor attached to C1 to  "true"
> T2 enters method M1of C1. BijectionInterceptor does nothing as "reentrant"  is true
> T1 exits method M1 of C1. As this is thios thread (T1) that set "reentrant" initially, it performs the "disinjection" and set all the @In  attribues of C1 to null
> T2 then fails with NPE as all the @In attributes of C1 are set to null !!!!!
> Core of the org.jboss.seam.core.BijectionInterceptor class:
>    private boolean reentrant; //OK, since all Seam components are single-threaded
>    @AroundInvoke
>    public Object aroundInvoke(InvocationContext invocation) throws Exception{
>       if (reentrant) {
>          return invocation.proceed();
>       }
>       else {
>          reentrant = true;
>          try {
>             Component component = getComponent();
>             boolean enforceRequired = !component.isLifecycleMethod( invocation.getMethod() );
>             component.inject( invocation.getTarget(), enforceRequired );
>             Object result = invocation.proceed();            
>             component.outject( invocation.getTarget(), enforceRequired );
>             component.disinject( invocation.getTarget() );
>             return result;
>          }
>          finally {
>             reentrant = false;
>          }
>       }
>    }

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

        



More information about the seam-issues mailing list