[ 
https://issues.apache.org/jira/browse/OFBIZ-5004?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=13439465#comment-13439465
 ] 

Jacques Le Roux commented on OFBIZ-5004:
----------------------------------------

+1 with Scott, missed that also. I mean test on field existence is ok for 
throwing exception with me, null value is not.
                
> Warning in GenericEntity.get unnecessarily clutters logs
> --------------------------------------------------------
>
>                 Key: OFBIZ-5004
>                 URL: https://issues.apache.org/jira/browse/OFBIZ-5004
>             Project: OFBiz
>          Issue Type: Bug
>          Components: framework
>    Affects Versions: SVN trunk
>            Reporter: Christoph Neuroth
>
> This code in GenericEntity.java:
> {code}Debug.logWarning("The field name (or key) [" + name + "] is not valid 
> for entity [" + this.getEntityName() + "], printing IllegalArgumentException 
> instead of throwing it because Map interface specification does not allow 
> throwing that exception.", module);
> {code}
> is really annoying and IMHO it is wrong. 
> First, it does not print an exception, it only prints that string with no 
> stacktrace (I think that was changed at some point).
> Second, IllegalArgument is a RuntimeException so the interface doesn't really 
> need to allow it to be thrown, right?
> Personally, I think the warning is not even justified. We sometimes don't 
> know exactly what kind of entity we're dealing with and just check if it has 
> that field or not. With this code, to prevent excessive log clutter, we have 
> to wrap each call with a "if (it.containsKey())". A java map will just return 
> null silently as well, and this behavior is documented in the Map interface. 
> If anyone is really worried about accessing fields wrong (your tests should 
> catch that error), there could be an extra method "getOrThrow" or something, 
> but get should just return the value or null.
> Otherwise, at least throw the exception. Log warnings are usually found while 
> monitoring production logs, developers will find this much earlier otherwise.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: 
https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

Reply via email to