Skip to content

Latest commit

 

History

History
90 lines (80 loc) · 4.54 KB

README.md

File metadata and controls

90 lines (80 loc) · 4.54 KB

sandpipers-cdk

Create and test AWS CDK stacks with ease using the Sandpipers CDK libraries.

Description

This project aims to create L3 constructs with sensible defaults that can be used as building blocks for your CDK stacks. It also provides a set of libraries to test your CDK stacks in a readable and maintainable way inspired by the AssertJ library.

The project is divided into the following modules:

Usage

  • Import the sandpipers-cdk-bom into to your pom.xml file.

    <dependencyManagement>
      <dependency>
        <groupId>io.sandpipers</groupId>
        <artifactId>sandpipers-cdk-bom</artifactId>
        <version>version</version>
        <type>pom</type>
        <scope>import</scope>
      </dependency>
    </dependencyManagement>
  • Add the sandpipers-cdk-core into to your pom.xml file, if you want to use the L3 constructs provided by the project.

    <dependency>
      <groupId>io.sandpipers</groupId>
      <artifactId>sandpipers-cdk-core</artifactId>
      <scope>test</scope>
    </dependency>
  • Use the constructs provided by the sandpipers-cdk-core in your CDK stacks. Examples of these constructs can be found in the sandpipers-cdk-examples module. However, here is a sneak peek of how to use the Lambda construct:

          final CustomRuntime2023FunctionProps functionProps = CustomRuntime2023FunctionProps.builder()
            .description("Example Function for CDK")
            .handler("org.springframework.cloud.function.adapter.aws.FunctionInvoker::handleRequest")
            .code(Code.fromAsset(testLambdaCodePath))
            .deadLetterTopicEnabled(true)
            .environment(Map.of("ENV", "TEST"))
            .build();
    
        final CustomRuntime2023Function<CustomRuntime2023FunctionProps> function =
            new CustomRuntime2023Function<>(this, SafeString.of("Function"), functionProps);
  • Add the sandpipers-cdk-assertions into to your pom.xml file, if you want to use the fluent assertions provided by the project.

    <dependency>
      <groupId>io.sandpipers</groupId>
      <artifactId>sandpipers-cdk-assertions</artifactId>
      <scope>test</scope>
    </dependency>
  • Use the assertions provided by the sandpipers-cdk-assertions in your CDK tests. Examples of these assertions can be found in the sandpipers-cdk-examples module. However, here is a sneak peek of how to use the CDKStackAssert.java assertions class for testing a Lambda function:

          CDKStackAssert.assertThat(template)
            .containsFunction("^Function[A-Z0-9]{8}$")
            .hasHandler("org.springframework.cloud.function.adapter.aws.FunctionInvoker::handleRequest")
            .hasCode("^cdk-sandpipers-assets-\\$\\{AWS\\:\\:AccountId\\}-\\$\\{AWS\\:\\:Region\\}$", "(.*).zip")
            .hasRole("^FunctionServiceRole[A-Z0-9]{8}$")
            .hasDependency("^FunctionServiceRoleDefaultPolicy[A-Z0-9]{8}$")
            .hasDependency("^FunctionServiceRole[A-Z0-9]{8}$")
            .hasTag("COST_CENTRE", "sandpipers")
            .hasTag("ENVIRONMENT", TEST)
            .hasTag("APPLICATION_NAME", "lambda-cdk-example")
            .hasEnvironmentVariable("ENV", TEST)
            .hasEnvironmentVariable("SPRING_PROFILES_ACTIVE", TEST)
            .hasDescription("Example Function for CDK")
            .hasMemorySize(512)
            .hasRuntime("provided.al2023")
            .hasTimeout(10)
            .hasMemorySize(512)
            .hasDeadLetterTarget("^FunctionDeadLetterTopic[A-Z0-9]{8}$");