From 5508780cc2768c34a54f3a8ca63063e173e87ed3 Mon Sep 17 00:00:00 2001 From: Philip Duncan Date: Wed, 20 Nov 2024 15:06:02 -0500 Subject: [PATCH] add requireImdsv2 to asg verifyNoLaunchConfigPropIsGiven --- .../aws-autoscaling/lib/auto-scaling-group.ts | 3 +++ .../test/auto-scaling-group.test.ts | 20 +++++++++++++++++++ 2 files changed, 23 insertions(+) diff --git a/packages/aws-cdk-lib/aws-autoscaling/lib/auto-scaling-group.ts b/packages/aws-cdk-lib/aws-autoscaling/lib/auto-scaling-group.ts index 05ea9b3a4c148..1a2c80a66f922 100644 --- a/packages/aws-cdk-lib/aws-autoscaling/lib/auto-scaling-group.ts +++ b/packages/aws-cdk-lib/aws-autoscaling/lib/auto-scaling-group.ts @@ -1758,6 +1758,9 @@ export class AutoScalingGroup extends AutoScalingGroupBase implements if (props.blockDevices) { throw new Error('Setting \'blockDevices\' must not be set when \'launchTemplate\' or \'mixedInstancesPolicy\' is set'); } + if (props.requireImdsv2) { + throw new Error('Setting \'requireImdsv2\' must not be set when \'launchTemplate\' or \'mixedInstancesPolicy\' is set'); + } } /** diff --git a/packages/aws-cdk-lib/aws-autoscaling/test/auto-scaling-group.test.ts b/packages/aws-cdk-lib/aws-autoscaling/test/auto-scaling-group.test.ts index 1ccbdd5f423ba..2b78904dd300c 100644 --- a/packages/aws-cdk-lib/aws-autoscaling/test/auto-scaling-group.test.ts +++ b/packages/aws-cdk-lib/aws-autoscaling/test/auto-scaling-group.test.ts @@ -2947,6 +2947,26 @@ describe('InstanceMaintenancePolicy', () => { }); }).toThrow(/The difference between minHealthyPercentage and maxHealthyPercentage cannot be greater than 100, got 200/); }); + + test('throws if requireImdsv2 set when launchTemplate is set', () => { + // GIVEN + const stack = new cdk.Stack(); + stack.node.setContext(AUTOSCALING_GENERATE_LAUNCH_TEMPLATE, true); + const vpc = mockVpc(stack); + const lt = LaunchTemplate.fromLaunchTemplateAttributes(stack, 'imported-lt', { + launchTemplateId: 'test-lt-id', + versionNumber: '0', + }); + + // THEN + expect(() => { + new autoscaling.AutoScalingGroup(stack, 'MyFleet', { + vpc, + launchTemplate: lt, + requireImdsv2: true, + }); + }).toThrow(/Setting \'requireImdsv2\' must not be set when \'launchTemplate\' or \'mixedInstancesPolicy\' is set/); + }); }); function mockSecurityGroup(stack: cdk.Stack) {