У меня есть следующая функция, которую я хочу проверить: < /p>
db.service.ts
async batchGet(keys: DynamoBatchRequest[], sorted = true, doNotFilterTtl = false): Promise {
const params: BatchGetCommandInput = {
RequestItems: {},
};
const start = Date.now();
LOGGER.debug(`DynamoDB before BatchGet: ${JSON.stringify(keys)}`);
params.RequestItems[this.tableName] = { Keys: keys };
return this.ddbClient
.send(new BatchGetCommand(params))
.then((data) => {
//return this.processGetWithRetry(data, [], start, 0, doNotFilterTtl);
return Promise.resolve([{ value: 'test1' }]);
})
/*.then((unsortedResult) => {
if (!sorted) {
LOGGER.debug('Return unsorted result.');
return unsortedResult;
}
return this.sortBatchResult(keys, unsortedResult);
})*/
.catch((err) => {
LOGGER.error(`DynamoDB BatchGet error: ${JSON.stringify(err)}, keys: ${JSON.stringify(keys)}`);
ErrorController.abortWithInternalServerError(`Failed getting item with error: ${JSON.stringify(err)}`);
});
}
< /code>
Я хочу издеваться над this.ddbclient.send < /strong>, чтобы контролировать результаты каждого обещания в этой цепочке, но я не заставляю его работать.
Чтобы упростить его, я прокомментировал вторую функцию ()
, поэтому моя первая цель - это то, что моя первая функция (). Тест: < /p>
db.service.test.ts
test.each(tests)('batchGet', async (mockedValue, result) => {
const mock = {
send: jest.fn().mockResolvedValueOnce(jest.fn().mockReturnValueOnce(Promise.resolve([{ value: 'test2' }]))),
};
// @ts-ignore
ddbService.ddbClient = mock;
let res = await ddbService.batchGet([], false);
expect(res).toEqual(result);
});
< /code>
Насколько я понимаю, это то, что это.ddbclient.send () должно вернуть обещание, которое также возвращает обещание, верно? Но это не работает ...
Любая помощь была бы очень оценена
Подробнее здесь: https://stackoverflow.com/questions/797 ... -with-jest
Цепные/вложенные обещания в тестах с шутками ⇐ Javascript
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение