Функция-заглушка, возвращающая обещание - PullRequest
0 голосов
/ 07 февраля 2020

Я пытаюсь выполнить модульное тестирование следующего контроллера:

export class MyController extends BaseController {

  constructor() {
      super();
      this.repository = new MyRepository();
  }

  public getData(req: Request, res: Response, next: NextFunction) {

      this.repository.getData(req.params.param1).then((result) => {
          return this.ok(req, res, result.resources)        // calls ok() method from base controller
      }, (err: Error) => {
          next(err)
      });
  }
}

Я хотел бы заглушить MyRepository.getData, который возвращает Promise<MyResult> Я также хочу заглушить метод BaseController.ok, чтобы гарантировать он вызывается с данными, возвращенными из репо. Вот мой тест:

it("should call the repository", (done) => {

        var mockReq = httpMocks.createRequest();
        var mockResp = httpMocks.createResponse();
        const mockNext: NextFunction = stub();

        mockReq.params.param1 = "value1";

        let sampleResult = new MyResult();
        const getDataStub = stub(MyRepository.prototype, "getData").resolves(sampleResult);
        const okStub = stub(MyController.prototype, "ok"); 

        new MyController().getData(mockReq, mockResp, mockNext);
        expect(getDataStub).to.have.been.calledWith("value1");    // passes ok
        expect(okStub).to.have.been.called;                       // fails 
        done()
    });

Тест не пройден при проверке, был ли вызван okStub хотя бы один раз. Если я отлаживаю код, я вижу, что на самом деле вызывается BaseController.ok, но после оценки в тесте.

1 Ответ

1 голос
/ 07 февраля 2020

Похоже, что код внутри getData.then перешел в другой цикл при событии l oop.

Попробуйте поместить done () внутри this.ok следующим образом

stub(MyController.prototype, "ok").callsFake(() => { done(); });

...