问题描述
我在 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 (将#修改为@)