Author: rgielen
Date: Sat Sep  7 13:26:25 2013
New Revision: 1520763

URL: http://svn.apache.org/r1520763
Log:
WW-4193 - Patch by Christoph Nenning
With this patch it is checked if devMode is active and if logMissingProperties 
is enabled before the exception is logged
- refactored shouldLogNoSuchPropertyWarning() to 
shouldLogMissingPropertyWarning() and using it to handle MethodFailedExceptions.
- updated void handleOgnlException(String expr, Object value, boolean 
throwExceptionOnFailure, OgnlException e) to use it.

Modified:
    
struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlValueStack.java

Modified: 
struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlValueStack.java
URL: 
http://svn.apache.org/viewvc/struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlValueStack.java?rev=1520763&r1=1520762&r2=1520763&view=diff
==============================================================================
--- 
struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlValueStack.java
 (original)
+++ 
struts/struts2/trunk/xwork-core/src/main/java/com/opensymphony/xwork2/ognl/OgnlValueStack.java
 Sat Sep  7 13:26:25 2013
@@ -203,10 +203,15 @@ public class OgnlValueStack implements S
     }
 
     private void handleOgnlException(String expr, Object value, boolean 
throwExceptionOnFailure, OgnlException e) {
-        String msg = "Error setting expression '" + expr + "' with value '" + 
value + "'";
-        if (LOG.isWarnEnabled()) {
+       boolean shouldLog = shouldLogMissingPropertyWarning(e);
+       String msg = null;
+       if (throwExceptionOnFailure || shouldLog) {
+               msg = "Error setting expression '" + expr + "' with value '" + 
value + "'";             
+       }
+       if (shouldLog) {
             LOG.warn(msg, e);
-        }
+       }
+       
         if (throwExceptionOnFailure) {
             throw new XWorkException(msg, e);
         }
@@ -320,7 +325,7 @@ public class OgnlValueStack implements S
     private Object handleOgnlException(String expr, boolean 
throwExceptionOnFailure, OgnlException e) {
         Object ret = findInContext(expr);
         if (ret == null) {
-            if (shouldLogNoSuchPropertyWarning(e)) {
+            if (shouldLogMissingPropertyWarning(e)) {
                 LOG.warn("Could not find property [" + 
((NoSuchPropertyException) e).getName() + "]");
             }
             if (throwExceptionOnFailure) {
@@ -330,8 +335,9 @@ public class OgnlValueStack implements S
         return ret;
     }
 
-    private boolean shouldLogNoSuchPropertyWarning(OgnlException e) {
-        return e instanceof NoSuchPropertyException && devMode && 
logMissingProperties;
+    private boolean shouldLogMissingPropertyWarning(OgnlException e) {
+        return (e instanceof NoSuchPropertyException || e instanceof 
MethodFailedException)
+                       && devMode && logMissingProperties;
     }
 
     private Object tryFindValue(String expr, Class asType) throws 
OgnlException {


Reply via email to