Hank Ibell created MYFACES-4030:
-----------------------------------

             Summary: MyFaces CDI support is disabled if non-CDI application is 
loaded first
                 Key: MYFACES-4030
                 URL: https://issues.apache.org/jira/browse/MYFACES-4030
             Project: MyFaces Core
          Issue Type: Bug
    Affects Versions: 2.2.10-SNAPSHOT
         Environment: WebSphere Liberty 8.5.5.8, Weld 2.3, MyFaces 2.2.8
            Reporter: Hank Ibell
            Priority: Minor


If MyFaces 2.2 is loaded at the server level, MyFaces CDI support is set once 
per server. This causes CDI-enabled JSF applications to not work properly if a 
non-CDI application is loaded first.

{panel:title=Steps to reproduce the error on WebSphere Liberty|bgColor=#e8e8e8}
1. Enable the jsf-2.2 and cdi-1.2 features on the WebSphere Liberty server.
2. Deploy two JSF applications: one that uses CDI (e.g. a flow built using 
FlowBuilder) and one that does not use CDI.
3. Make a request to the non-CDI application first. The message 'MyFaces CDI 
support disabled' should be written to the logs.
4. Make a request to the CDI-enabled application. If testing an application 
with a flow built using FlowBuilder, the flow will not be discovered.
{panel}

I've investigated the issue and found that MyFaces has two conditions to 
determine CDI availability:
1. CDI must be found on the classpath
2. The application map must have a bean manager instance

(Found inside org.apache.myfaces.util.ExternalSpecifications#isCDIAvailable()).

When MyFaces is shared between different applications, basing CDI availability 
on an application's configuration (condition two) is an issue.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to