Использование Jest совместно с DynamoDB
С помощью Глобальных настроек/Teardown и Async Test Environment API, Jest может нормально работать с DynamoDB.
Используйте предустановку jest-dynamodb
Jest DynamoDB предоставляет всю необходимую конфигурацию для запуска ваших тестов с помощью DynamoDB.
- Сначала установите @shelf/jest-dynamodb
- npm
- Yarn
- pnpm
npm install --save-dev @shelf/jest-dynamodb
yarn add --dev @shelf/jest-dynamodb
pnpm add --save-dev @shelf/jest-dynamodb
- Укажите preset в конфигурации Jest:
{
  "preset": "@shelf/jest-dynamodb"
}
- Создайте jest-dynamodb-config.jsи определите динамические таблицы
Смотрите Создать API таблицы
module.exports = {
  tables: [
    {
      TableName: `files`,
      KeySchema: [{AttributeName: 'id', KeyType: 'HASH'}],
      AttributeDefinitions: [{AttributeName: 'id', AttributeType: 'S'}],
      ProvisionedThroughput: {ReadCapacityUnits: 1, WriteCapacityUnits: 1},
    },
    // etc
  ],
};
- Настройка клиента DynamoDB
const {DocumentClient} = require('aws-sdk/clients/dynamodb');
const isTest = process.env.JEST_WORKER_ID;
const config = {
  convertEmptyValues: true,
  ...(isTest && {
    endpoint: 'localhost:8000',
    sslEnabled: false,
    region: 'local-env',
  }),
};
- Напишите тест
it('should insert item into table', async () => {
  await ddb
    .put({TableName: 'files', Item: {id: '1', hello: 'мир'}})
    .promise();
  const {Item} = await ddb.get({TableName: 'files', Key: {id: '1'}}).promise();
  expect(Item).toEqual({
    id: '1',
    hello: 'мир',
  });
});
Нет необходимости загружать зависимости.
См. документацию для деталей.