From 05a49f0b1eb7dd391c4fd05d3ab86cdcae6bda65 Mon Sep 17 00:00:00 2001 From: Adam Ruka Date: Tue, 2 Jul 2019 22:52:25 -0700 Subject: [PATCH] feat(codedeploy): allow setting a Deployment Configuration for an imported Lambda Deployment Group. (#3158) --- .../lib/lambda/deployment-group.ts | 20 +++++++++++++++++-- .../test/lambda/test.deployment-group.ts | 18 ++++++++++++++++- 2 files changed, 35 insertions(+), 3 deletions(-) diff --git a/packages/@aws-cdk/aws-codedeploy/lib/lambda/deployment-group.ts b/packages/@aws-cdk/aws-codedeploy/lib/lambda/deployment-group.ts index 0fcddbb7526ee..9e9576553e448 100644 --- a/packages/@aws-cdk/aws-codedeploy/lib/lambda/deployment-group.ts +++ b/packages/@aws-cdk/aws-codedeploy/lib/lambda/deployment-group.ts @@ -29,6 +29,11 @@ export interface ILambdaDeploymentGroup extends cdk.IResource { * @attribute */ readonly deploymentGroupArn: string; + + /** + * The Deployment Configuration this Group uses. + */ + readonly deploymentConfig: ILambdaDeploymentConfig; } /** @@ -52,7 +57,7 @@ export interface LambdaDeploymentGroupProps { /** * The Deployment Configuration this Deployment Group uses. * - * @default LambdaDeploymentConfig#AllAtOnce + * @default LambdaDeploymentConfig.CANARY_10PERCENT_5MINUTES */ readonly deploymentConfig?: ILambdaDeploymentConfig; @@ -135,6 +140,7 @@ export class LambdaDeploymentGroup extends cdk.Resource implements ILambdaDeploy public readonly application: ILambdaApplication; public readonly deploymentGroupName: string; public readonly deploymentGroupArn: string; + public readonly deploymentConfig: ILambdaDeploymentConfig; public readonly role: iam.IRole; private readonly alarms: cloudwatch.IAlarm[]; @@ -154,12 +160,13 @@ export class LambdaDeploymentGroup extends cdk.Resource implements ILambdaDeploy }); this.role.addManagedPolicy(iam.ManagedPolicy.fromAwsManagedPolicyName('service-role/AWSCodeDeployRoleForLambda')); + this.deploymentConfig = props.deploymentConfig || LambdaDeploymentConfig.CANARY_10PERCENT_5MINUTES; const resource = new CfnDeploymentGroup(this, 'Resource', { applicationName: this.application.applicationName, serviceRoleArn: this.role.roleArn, deploymentGroupName: this.physicalName, - deploymentConfigName: (props.deploymentConfig || LambdaDeploymentConfig.ALL_AT_ONCE).deploymentConfigName, + deploymentConfigName: this.deploymentConfig.deploymentConfigName, deploymentStyle: { deploymentType: 'BLUE_GREEN', deploymentOption: 'WITH_TRAFFIC_CONTROL' @@ -262,17 +269,26 @@ export interface LambdaDeploymentGroupAttributes { * that we are referencing. */ readonly deploymentGroupName: string; + + /** + * The Deployment Configuration this Deployment Group uses. + * + * @default LambdaDeploymentConfig.CANARY_10PERCENT_5MINUTES + */ + readonly deploymentConfig?: ILambdaDeploymentConfig; } class ImportedLambdaDeploymentGroup extends cdk.Resource implements ILambdaDeploymentGroup { public readonly application: ILambdaApplication; public readonly deploymentGroupName: string; public readonly deploymentGroupArn: string; + public readonly deploymentConfig: ILambdaDeploymentConfig; constructor(scope: cdk.Construct, id: string, props: LambdaDeploymentGroupAttributes) { super(scope, id); this.application = props.application; this.deploymentGroupName = props.deploymentGroupName; this.deploymentGroupArn = arnForDeploymentGroup(props.application.applicationName, props.deploymentGroupName); + this.deploymentConfig = props.deploymentConfig || LambdaDeploymentConfig.CANARY_10PERCENT_5MINUTES; } } diff --git a/packages/@aws-cdk/aws-codedeploy/test/lambda/test.deployment-group.ts b/packages/@aws-cdk/aws-codedeploy/test/lambda/test.deployment-group.ts index a9095766e7e34..b80662f5ede3f 100644 --- a/packages/@aws-cdk/aws-codedeploy/test/lambda/test.deployment-group.ts +++ b/packages/@aws-cdk/aws-codedeploy/test/lambda/test.deployment-group.ts @@ -581,5 +581,21 @@ export = { test.done(); }, - } + + 'imported with fromLambdaDeploymentGroupAttributes': { + 'defaults the Deployment Config to Canary10Percent5Minutes'(test: Test) { + const stack = new cdk.Stack(); + + const lambdaApp = codedeploy.LambdaApplication.fromLambdaApplicationName(stack, 'LA', 'LambdaApplication'); + const importedGroup = codedeploy.LambdaDeploymentGroup.fromLambdaDeploymentGroupAttributes(stack, 'LDG', { + application: lambdaApp, + deploymentGroupName: 'LambdaDeploymentGroup', + }); + + test.equal(importedGroup.deploymentConfig, LambdaDeploymentConfig.CANARY_10PERCENT_5MINUTES); + + test.done(); + }, + }, + }, };