Uploaded image for project: 'MyFaces Core'
  1. MyFaces Core
  2. MYFACES-3413

Default MyFaces Error handling throws NullPointerException during component tree when javax.el.Expression.getExpressionString() is null

Attach filesAttach ScreenshotVotersWatch issueWatchersCreate sub-taskLinkCloneUpdate Comment AuthorReplace String in CommentUpdate Comment VisibilityDelete Comments


    • Type: Bug
    • Status: Closed
    • Priority: Minor
    • Resolution: Fixed
    • Affects Version/s: 2.1.3
    • Fix Version/s: 2.0.11, 2.1.5
    • Component/s: JSR-314
    • Labels:


      The default MyFaces Error handling throws a NullPointerException during the writing out of the component tree when an attribute's ValueExpression.getExpressionString() returns null.

      As an example, this can happen with Richfaces 4.1.x skinning as the org.richfaces.application.GlobalResourcesViewHandler$SkinningResourceRenderedExpression
      used for "rendered" on the __rf_skinning_resource UIOutput has a null value for getExpressionString().

      From what I can tell, it's legal for Expression.getExpressionString() to return null.


      In any case, since this is an error handling routine, it should
      probably be more flexible in handling unexpected values.

      What do we want to do in this case?

      We could skip outputting the attribute.

      We could output the attribute with empty string as the value expression.

      In this particular case, we could check for isReadOnly() and if true, output getValue(). Not sure if we'd want to do that in the case of !isReadOnly(). In fact, I'm not entirely certain we want to be evaluating getValue().

      We could output the class of the value expression.

      As a first pass, I am going to output the value expression as the empty string.




            • Assignee:
              mkienenb Mike Kienenberger
              mkienenb Mike Kienenberger


              • Created:

                Issue deployment