Zum Hauptinhalt springen
Version: 29.7

Verwendung mit DynamoDB

Inoffizielle Beta-Übersetzung

Diese Seite wurde von PageTurner AI übersetzt (Beta). Nicht offiziell vom Projekt unterstützt. Fehler gefunden? Problem melden →

Mit den APIs für Globales Setup/Abbauen und Asynchrone Testumgebung kann Jest nahtlos mit DynamoDB zusammenarbeiten.

Verwendung des jest-dynamodb Presets

Jest DynamoDB bietet alle erforderlichen Konfigurationen, um Ihre Tests mit DynamoDB auszuführen.

  1. Installieren Sie zunächst @shelf/jest-dynamodb
npm install --save-dev @shelf/jest-dynamodb
  1. Geben Sie das Preset in Ihrer Jest-Konfiguration an:
{
"preset": "@shelf/jest-dynamodb"
}
  1. Erstellen Sie jest-dynamodb-config.js und definieren Sie DynamoDB-Tabellen

Siehe Create Table API

module.exports = {
tables: [
{
TableName: `files`,
KeySchema: [{AttributeName: 'id', KeyType: 'HASH'}],
AttributeDefinitions: [{AttributeName: 'id', AttributeType: 'S'}],
ProvisionedThroughput: {ReadCapacityUnits: 1, WriteCapacityUnits: 1},
},
// etc
],
};
  1. Konfigurieren Sie den DynamoDB-Client
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',
}),
};

const ddb = new DocumentClient(config);
  1. Schreiben Sie Tests
it('should insert item into table', async () => {
await ddb
.put({TableName: 'files', Item: {id: '1', hello: 'world'}})
.promise();

const {Item} = await ddb.get({TableName: 'files', Key: {id: '1'}}).promise();

expect(Item).toEqual({
id: '1',
hello: 'world',
});
});

Es ist nicht notwendig, Abhängigkeiten manuell zu laden.

Details finden Sie in der Dokumentation.