Function Error
Description: When a specific function in your code returns FALSE, it generates an event. The “Function Error” Rule contains a list of monitored functions (i.e. functions that when returning FALSE will trigger an event).
Information Collected:
The most important details are:
- Function Name - As displayed in the Issue’s General Details
- Function Arguments - The arguments of the function that triggered the event are listed in the Function Data tab.
- Backtrace – identify what happened before the error happened that may have caused a problem such as incorrect data or problematic input data.
In most cases, these details alone should be enough to indicate what triggered the event.
Applicable Diagnostic Actions:
Click on a link to see how to perform each action tools are listed in order of relevance to helping solve the event:
- Run the Debugger
- Open code in editor
- Redefine database queries
- View information in the Logs
- Run the Profiler
Possible Causes and Solutions:
Generally, logic errors trigger Function Error events such as queries that you expect to return something and they do not and not PHP errors.
If you have a function that you need to return FALSE as an acceptable value, remove the function from the monitored functions list.
- Internal PHP functions – If you are using internal PHP functions, the best reference for investigating the problem is use the PHP manual (The Zend Controller’s Search option provides quick access to searching the PHP Manual.
- You can also check your logs to see if they show PHP error information logged the same time the function error occurred.
- User define functions – If it is a user defined function, running the debugger will help find out if the function is running complicated actions that are causing the function to fail. Using Breakpoints while debugging, will further pinpoint the problematic area in the code.
- False Positives - Sometimes functions are supposed to return FALSE. Not all functions that return FALSE are indicative of a problem in your code or environment and they may be no indication of unacceptable behavior. If this is the case, remove the function from the Rule’s “Event Condition” list or set the status of issues triggered by this function to ignored.
Note:
Removing a function from the rule, affects all instances of the function. Before removing the function from the list, make sure the function does not require monitoring wherever it is used.