嗨,我正在尝试编写mocha chai测试,以测试过期的jwt是否可以创建新条目
it("Should NOT Allow user to create a new diary entry with an expired Token", done => {
const entryTestData5 = {
title: "diary",
detail: "my new diary"
};
const token = "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmaXJzdE5hbWUiOiJmaXJzdE5hbWUiLCJsYXN0TmFtZSI6Imxhc3ROYW1lIiwiZW1haWwiOiJleGFtcGxlQGdtYWlsLmNvbSIsInJlbWluZGVyIjoib2ZmIiwiaWF0IjoxNTcxOTEyOTc2LCJleHAiOjE1NzE5MTI5Nzh9.2ETTnItxbaPJiAcDubq2fxSr6SXcPEo3VN8lcjVcl7M";
chai
.request(app)
.post("/api/v1/entry")
.set("auth", token)
.send(entryTestData5)
.end((err, res) => {
expect(res).to.have.status(403);
expect(res.body).to.have.property("message");
done();
});
});
并且在尝试运行测试时收到以下警告
(node:9464) UnhandledPromiseRejectionWarning: Error [ERR_HTTP_HEADERS_SENT]: Cannot set headers after they are sent to the client
at ServerResponse.setHeader (_http_outgoing.js:470:11)
at ServerResponse.header (C:\Users\PRO\Desktop\API\node_modules\express\lib\response.js:771:10)
at ServerResponse.send (C:\Users\PRO\Desktop\API\node_modules\express\lib\response.js:170:12)
at ServerResponse.json (C:\Users\PRO\Desktop\API\node_modules\express\lib\response.js:267:15)
at ServerResponse.send (C:\Users\PRO\Desktop\API\node_modules\express\lib\response.js:158:21)
at _callee$ (C:\Users\PRO\Desktop\API\Server\middleware\authenticate.js:1:7679)
at tryCatch (C:\Users\PRO\Desktop\API\node_modules\regenerator-runtime\runtime.js:45:40)
at Generator.invoke [as _invoke] (C:\Users\PRO\Desktop\API\node_modules\regenerator-runtime\runtime.js:271:22)
at Generator.prototype.(anonymous function) [as next] (C:\Users\PRO\Desktop\API\node_modules\regenerator-runtime\runtime.js:97:21)
at asyncGeneratorStep (C:\Users\PRO\Desktop\API\node_modules\@babel\runtime\helpers\asyncToGenerator.js:3:24)
at _next (C:\Users\PRO\Desktop\API\node_modules\@babel\runtime\helpers\asyncToGenerator.js:25:9)
at process._tickCallback (internal/process/next_tick.js:68:7)
(节点:9464)UnhandledPromiseRejectionWarning:未处理的承诺拒绝。引发此错误的原因可能是抛出了一个没有catch块的异步函数,或者是拒绝了一个.catch()无法处理的承诺。 (拒绝ID:1) (节点:9464)[DEP0018] DeprecationWarning:已弃用未处理的承诺拒绝。将来,未处理的承诺拒绝将以非零退出代码终止Node.js进程。
如果有人可以帮助您,请
以下是我的服务器
import jwt from "jsonwebtoken";
import userModel from "../models/User";
async function checkToken(req, res, next) {
const token = await req.headers.auth;
let InUserEmail;
if (typeof token !== "undefined") { jwt.verify(token, process.env.SECRET, (err, result) => {
if (err) {
if (err.name === "TokenExpiredError") {
return res.status(403).send({
message: "TokenExpired"
});
}
} else {
InUserEmail = result.email;
req.tokenData = jwt.verify(token, process.env.SECRET);
}
});
const authUser = userModel.users.find(user => user.email === InUserEmail);
if (!authUser) {
return res.status(401).send({
message: "not authorized to do the task"
});
} next();
} else {
res.status(403).send({
message: "not authorized to do the task(forbidden)"
});
}}
export default checkToken;