web-dev-qa-db-ja.com

JESTを使用したエクスプレスルートのテスト

JESTを使用してExpress APIエンドポイントをテストしたいと思いました。

以下は私のExpress APIコードです。

routs.ts

// Get release notes
routes.get('/release-notes', (req, res) => {
  request.get({
    url: 'https://Host.com/rest/api/content/search?cql=parent=209266565',
    json: true
  })
    .pipe(res);
});

export default routes;

上記のコードはデータを返しますが、APIリクエストを行わずにMockでAPIをテストしたいと思います

だから私は手動で模擬応答を作成し、それでコードを検証する必要があります。

Mock.ts

export const releaseNotesMockData = {
  'results': [
    {
      'id': '206169942',
      'type': 'page',
      'status': 'current',
      'title': 'Release 2018-10-18 Full Flow CM00294965',
    }]
};

以下のコードを使用して、実際のAPIにアクセスし、テストに合格しました

describe('Test a 200', () => {
    test('It should respond with a 200 status', async () => {
      const response = await request(app).get('/release-notes');
      expect(response.statusCode).toBe(200);
    });
  });

問題は、テストのために実際のAPIにアクセスしたくないことです。代わりに、モックをテストに使用したいのです。

以下は私が試したコードで、うまくいきませんでした。助けてください

routs.test.ts

describe('api test', () => {
  const url = '/release-notes';
  it('user GET should be 200', async () => {
    const result = await http({
      url,
      method: 'get'
    });
    expect(result).toBe('200');
  });
});
6
Aw3 Sol

問題は、インポートするrequestモジュールをモックしていないことです。

モックの詳細については、 https://jestjs.io/docs/en/tutorial-async を参照してください。

1
Francisco Mateo