I'm not sure why I'm seeing this UnhandledPromiseRejectionWarning. In this code, 'id' is a Mongoose Index, and I am testing inserting a duplicate ID which should be handled properly.
router.post('/create/:id', jsonParser, (req: Request, res: Response) => {
let { id } = req.params;
if (!req.body) {
return res.sendStatus(400)
}
// @TODO add validation on JSON
let promise = Requirement.create({id: id, data: req.body.data, deleted: false});
promise.then((requirement) => {
return res.json(requirement);
});
promise.catch((reason) => {
let err = {'error': reason};
return res.json(err);
});
});
In fact, the following JSON is returned, so I know my rejection handler is executing:
{
"error": {
"name": "MongoError",
"message": "E11000 duplicate key error collection: rex.requirements index: id_1 dup key: { : \"REQ001\" }",
"driver": true,
"index": 0,
"code": 11000,
"errmsg": "E11000 duplicate key error collection: rex.requirements index: id_1 dup key: { : \"REQ001\" }"
}
}
The exact warnings I'm seeing are the following:
(node:11408) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 1): MongoError: E11000 duplicate key error collection: rex.requirements index: id_1 dup key: { : "REQ001" }
(node:11408) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.