handle-callback-err (ESLint: handle-callback-err)
enforce error handling in callbacks
In Node.js, a common pattern for dealing with asynchronous behavior is called the callback pattern. This pattern expects an Error object or null as the first argument of the callback. Forgetting to handle these errors can lead to some really strange behavior in your application.
The rule takes a string option: the name of the error parameter. The default is
"err"
.
Sometimes the name of the error variable is not consistent across the project, so you need a more flexible configuration to ensure that the rule reports all unhandled errors.
If the configured name of the error variable begins with a ^
it is considered to be a
regexp pattern.
- If the option is
"^(err|error|anySpecificError)$"
, the rule reports unhandled errors where the parameter name can beerr
,error
oranySpecificError
. - If the option is
"^.+Error$"
, the rule reports unhandled errors where the parameter name ends withError
(for example,connectionError
orvalidationError
will match). - If the option is
"^.*(e|E)rr"
, the rule reports unhandled errors where the parameter name matches any string that containserr
orErr
(for example,err
,error
,anyError
,some_err
will match).
In addition to the string we may specify an options object with the following property:
allowProperties
: (true
by default) When this is set tofalse
the rule will not report unhandled errors as long as the error object is handled without accessing any of its properties at least once. For instance,(err) => console.log(err.stack)
would report an issue whenallowProperties
is set tofalse
becauseerr
is not handled on its own.
"handle-callback-err": [true, "error"]
"handle-callback-err": [true, "^(err|error|anySpecificError)$"]
"handle-callback-err": [true, { "allowProperties": false }]
"handle-callback-err": [true, "^(err|error|anySpecificError)$", { "allowProperties": false }]
{
"type": "array",
"items": [
{
"type": "string"
},
{
"type": "object",
"properties": {
"allowProperties": "boolean"
},
"additionalProperties": false
}
],
"minLength": 0,
"maxLength": 2
}