[Node.Js套接字在将自定义Error类传递到Express错误中间件时挂断

问题描述 投票:0回答:1

[我正在尝试为我的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时,我看到123foobar出现了,因此已被传递到中间件中。但是,似乎有些事情正在发生,但我并不了解。

我已经进行了一些研究,并且似乎在过程未正确关闭的地方发生了一些事情,但是我不确定扩展基本错误类将如何导致这种情况发生。

提前感谢您的帮助。

javascript node.js express mocha chai
1个回答
0
投票

我知道了这个问题。在测试中,我将123作为foobar状态代码进行传递,然后将其传递到我的错误处理程序中的res.status(123)中。我猜想Node(或Express)可以防止发送无效的状态代码,因为一旦将123更改为400,套接字错误就消失了。

© www.soinside.com 2019 - 2024. All rights reserved.