如何解决SINON - 模拟中间件的问题
我在 Node.js REST API 中有以下中间件
const Authorized = (req,res,next) => {
if (!req.headers["authorization"]) {
res.status(401).send("Unauthorized");
} else {
jwt.verify(req.headers["authorization"],PRIVATE_KEY,(err,decoded) => {
if (err) {
res.status(403).send("Forbidden");
} else {
req.businessId = decoded.businessId;
req.roleId = decoded.roleId;
next();
}
});
}
};
如您所见,我正在向请求对象添加变量
在我的测试模型中,我试图这样做:
sandBox = sinon.createSandBox();
sandBox.stub(Authorized,"Authorized")
.callsFake(async (req,next) => {
req.businessId = businessAux.id;
return next();
});
但这不起作用,我要测试的实际功能需要这个变量:
listPermissionAndRolesByPk() {
this.app.get(`${config.API_PATH}/permissionrolebypk`,Authorized.Authorized,async (req,res) => {
const id = req.query.id;
const businessId = req.businessId;
if (!id) return res.status(400).send(messages[23].message.replace("${object}","Permission Id"));
try {
const permission = await PermissionDAO.getPermissionAndRolesByPk(id,businessId ? businessId : 0);
if (permission) {
return res.status(200).json(permission);
} else {
return res.status(404).send(messages[8].message.replace("${object}","Permission"));
}
} catch (error) {
return res.status(error.httpCode).send(error.message);
}
});
}
任何帮助将不胜感激。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。