借助全局設(shè)置/拆卸和異步測(cè)試環(huán)境API,Jest 可以與DynamoDB順利工作。
Jest DynamoDB提供了使用 DynamoDB 運(yùn)行測(cè)試所需的所有配置。
首先,安裝 ?@shelf/jest-dynamodb
yarn add @shelf/jest-dynamodb --dev
在 Jest 配置中指定預(yù)設(shè)
{
"preset": "@shelf/jest-dynamodb"
}
創(chuàng)建?jest-dynamodb-config.js?和定義 DynamoDB 表
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',
}),
};
const ddb = new DocumentClient(config);
編寫(xiě)測(cè)試
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',
});
});
無(wú)需加載任何依賴項(xiàng)。
有關(guān)詳細(xì)信息,請(qǐng)參閱文檔。
更多建議: