Skip to content

Latest commit

 

History

History
74 lines (47 loc) · 4.77 KB

File metadata and controls

74 lines (47 loc) · 4.77 KB

Asynchronous Integration Test Harness with Lambda and DynamoDB

You may use a variety of resource types to create the test harness for your asynchronous system under test (more about event listeners). We recommend starting with AWS Lambda and Amazon DynamoDB. DynamoDB creates a persistent storage resource that can enable long running tests or an aggregation of a set of results.

In this pattern, a Lambda function is configured to be an event listener to receive the System Under Test's output data. DynamoDB is configured to be the event listener storage option. In Step 1 in the diagram below, the test establishes a long polling pattern with DynamoDB. In Step 2, the test sends input data to the asynchronous system under test. The async system processes the data and in Step 3 the the Lambda function receives the data and puts it into DynamoDB. The long poll queries DynamoDB and examines the result. We recommend writing tests for failure conditions including timeouts and malformed requests.

AWS Lambda and AmazonDynamoDB

[top]

Review the System Under Test

The System Under Test (SUT) in this example is an asynchronous text processor. It contains a source S3 bucket that receives a text file. A Lambda function is configured to be notified when the putObject event is executed on this bucket. The Lambda function gets the file from the source bucket, transforms the contents of the file to uppercase, then puts the file into a destination S3 bucket.

S3 to Lambda to S3

Your goal is to test this asynchronous process. You will use the Lambda Event Listener and DynamoDB test pattern to test the process. You will deploy the following resources:

  • S3 Source Bucket
  • Lambda function text processor
  • S3 Destination Bucket
  • Lambda event listener (test environments only)
  • DynamoDB results storage (test environments only)

[top]

Prerequisites

The SAM CLI is an extension of the AWS CLI that adds functionality for building and testing serverless applications. It contains features for building your appcation locally, deploying it to AWS, and emulating AWS services locally to support automated unit tests.

To use the SAM CLI, you need the following tools.

This project uses the make build automation tool to provide convenient commands for building, deploying and testing this sample application. To view the available commands make sure this utility is installed and run the make command in the terminal from the same directory as the Makefile.

[top]

Build the project

  • make install - Install virtual environment
  • make build - Build the project locally.

[top]

Deploy project resources to the cloud

  • make deploy.g - Deploy the project to the AWS cloud for the first time.
  • make deploy - Deploy subsequent changes to the AWS cloud. This command uses a saved configuration file for configurations.

The deploy process accepts a parameter named DeployTestResources. The allowed values for this parameter are true and false. If you pass true as this parameter's value CloudFormation will attempt to deploy the test event listener and storage resources (Lambda and DynamoDB) to your account. If you pass false these resources will not be deployed.

[top]

Run the tests

Install a virtual environment to install the development dependencies and execute your tests. Run these four commands in sequence.

  • make deps - Install project dependencies locally
  • make test - Run integration test against cloud environment (requires AWS_SAM_STACK_NAME variable)
    • usage: make AWS_SAM_STACK_NAME=<your-aws-stack-name> test

[top]

Cleanup

  • make clean - Cleans up local build artifacts including zip files
  • make delete - Delete stack from AWS cloud
  • exit - Close the virtual environment shell

[top]