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');
});
});
問題は、インポートするrequest
モジュールをモックしていないことです。
モックの詳細については、 https://jestjs.io/docs/en/tutorial-async を参照してください。