Utilizzo con DynamoDB
Traduzione Beta Non Ufficiale
Questa pagina è stata tradotta da PageTurner AI (beta). Non ufficialmente approvata dal progetto. Hai trovato un errore? Segnala problema →
Grazie alle API di Configurazione/Chiusura Globale e Ambiente di Test Asincrono, Jest può funzionare senza problemi con DynamoDB.
Utilizzare il preset jest-dynamodb
Jest DynamoDB fornisce tutta la configurazione necessaria per eseguire i tuoi test con DynamoDB.
- Per prima cosa, installa
@shelf/jest-dynamodb
- npm
- Yarn
- pnpm
- Bun
npm install --save-dev @shelf/jest-dynamodb
yarn add --dev @shelf/jest-dynamodb
pnpm add --save-dev @shelf/jest-dynamodb
bun add --dev @shelf/jest-dynamodb
- Specifica il preset nella tua configurazione di Jest:
{
"preset": "@shelf/jest-dynamodb"
}
- Crea
jest-dynamodb-config.jse definisci le tabelle di DynamoDB
Consulta l'API Crea Tabella
module.exports = {
tables: [
{
TableName: `files`,
KeySchema: [{AttributeName: 'id', KeyType: 'HASH'}],
AttributeDefinitions: [{AttributeName: 'id', AttributeType: 'S'}],
ProvisionedThroughput: {ReadCapacityUnits: 1, WriteCapacityUnits: 1},
},
// etc
],
};
- Configura il client 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',
}),
};
const ddb = new DocumentClient(config);
- Scrivi i test
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',
});
});
Non è necessario caricare alcuna dipendenza.
Consulta la documentazione per i dettagli.