Testing

Testing the “OrderManager.WaitingCompletion” Rule

Step-by-step instructions

  1. Single Order Test
    • Create a new order.
    • Check the serverlesspresso-metrics-table
    • Workflow Architecture
    • You’ll see 2 items: (Similar to screenshot above)
      • 2022-XX-XX#TotalSales
      • 2022-XX-XX#ItemName
    • These values are incremented each time there’s an OrderManager.WaitingCompletion event in the Event Bus.
  2. Load Testing
  • We’ll now use a Lambda function to simulate a large number of orders and see how SQS can act as a buffer for event processing during traffic spikes.
  • These events will be matched with the WaitingCompletion rule and sent to the MetricsQueue.
  • Before you run the load test, let’s look at how Lambda will process messages off the queue.
  • Each invocation of the Lambda function will process the events in batches of up to 10 records or windows of 30 seconds. Reserved Concurrency defines how many concurrent Lambda executions would read messages off the queue, the default is up to 1000 concurrent executions at any given time. By using Reserved Concurrency, we’re saying there should only be 1 concurrent execution of this specific Lambda function.
  • You can customize the ReservedConcurrentExecutions, BatchSize, and MaximumBatchingWindowInSeconds values to adjust how many records are processed at any given time, our current configuration means we’ll process up to 10 records per Lambda execution.
  • You can check the serverless-order-metrics table items to see the metrics as they’re updated during the load test. You’ll see four metrics; counts for each item type and a total order count.
  • Navigate to the Lambda console and search for the EventsLoadTest Lambda function
  • Lambda Console Search
  • Invoke the EventsLoadTest Lambda function to simulate OrderManager.WaitingCompletion events in the Event Bus by clicking on the orange Test button.
  • Invoke Lambda Function
  • You will be prompted to create a test event.
  • For the Event Name, enter Test
  • For the Event JSON, you can use the default value.
  • Lambda Test Event
  • Click Save, then click on the orange Test button again to execute the load test.
  1. Viewing Load Test Results:
  • Open up the PublishMetrics Lambda function and navigate to the Monitoring tab. Expand the PublishMetrics function Invocations graph and select “Maximum” instead of “Sum”. You’ll see only 1 concurrent execution during the load test. Instead of scaling to process all the messages in the SQS Queue, Reserved Concurrency limited the function to only 1 concurrent execution.
  • Check the serverlesspresso-metrics-table table items.
    • You’ll see around around 500 total orders were simulated during the load test.
  • Invocations Graph
  • Open up theserverlesspresso-metrics-table DynamoDB table and navigate to the Monitor tab. Expand the Write usage graph and select “Maximum” instead of “Sum”. The Red line represents the provisioned capacity for the table whereas the blue line represents how many WCU’s were consumed by the PublishMetrics function. Without the Reserved Concurrency configuration and SQS queue in place, the Lambda function would’ve scaled to many concurrent executions, consumed all of the Provisioned Write Capacity, and been throttled by the DynamoDB table as it tried to insert metrics.
  • WCU Graph

Takeaways

  • We were able to provide business metrics for the investors by setting up a new rule and microservice without needing to modify the existing application stack.
  • Using SQS as a buffer between the Event Bus and Lambda prevents database throttling when updating downstream systems like DynamoDB.
  • Using Cloudwatch metrics to assess the performance of your event driven design can help identify weak points in your architecture.