[我正在尝试为我的Node + Express服务器中的错误处理中间件编写集成测试,并且在传递扩展Node基本错误类的自定义错误时遇到套接字挂起的情况。
Err.ts
class Err extends Error {
public status: number;
constructor(message: string, status: number) {
super(message);
this.status = status;
}
}
errorHandler.ts
const errorHandler: ErrorRequestHandler = (err: Err, _req, res, _next) => {
res.status(err.status || 500).json({
success: false,
error: err.message || 'Server error'
});
};
整合测试
// SETUP
use(chaiHttp);
const app = express();
app.get('/foo', (_req, _res, next) => {
return next(new Error());
});
app.get('/qux', (_req, _res, next) => {
return next(new Err('foobar', 123));
});
app.use(errorHandler);
// TESTING GENERIC, NORMAL NODE ERROR --> THIS WORKS
it('returns a default error when error object is malformed', async () => {
const res = await request(app).get('/foo');
expect(res.status).to.equal(500);
expect(res.body.error).to.equal('Server error');
});
// TESTING CUSTOM ERROR --> THIS THROWS THE SOCKET ERROR
it('returns the passed-in error as is', async () => {
const res = await request(app).get('/qux');
expect(res.status).to.equal(123);
expect(res.body.error).to.equal('foobar');
});
// STACK
Error: socket hang up
at connResetException (internal/errors.js:570:14)
at Socket.socketOnEnd (_http_client.js:440:23)
at endReadableNT (_stream_readable.js:1185:12)
at processTicksAndRejections (internal/process/task_queues.js:81:21)
[还有其他值得注意的地方是,当我在console.log(err.status, err.message)
中显示errorHandler.ts
时,我看到123
和foobar
出现了,因此已被传递到中间件中。但是,似乎有些事情正在发生,但我并不了解。
我已经进行了一些研究,并且似乎在过程未正确关闭的地方发生了一些事情,但是我不确定扩展基本错误类将如何导致这种情况发生。
提前感谢您的帮助。
我知道了这个问题。在测试中,我将123
作为foobar状态代码进行传递,然后将其传递到我的错误处理程序中的res.status(123)
中。我猜想Node(或Express)可以防止发送无效的状态代码,因为一旦将123更改为400,套接字错误就消失了。