Skip to content

Commit

Permalink
address comments
Browse files Browse the repository at this point in the history
  • Loading branch information
ahammond committed Apr 17, 2024
1 parent 67d83c5 commit 2186314
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 61 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -620,25 +620,13 @@ abstract class ExternalApplicationListener extends Resource implements IApplicat
*
* It's possible to add conditions to the TargetGroups added in this way.
* At least one TargetGroup must be added without conditions.
*
* NOTE: if you are deploying new infrastructure using this method,
* it is recommended to set the `removeRuleSuffixFromLogicalId: false`
* property so that the logicalId for the generated `ListenerRule`
* is consistent with other methods for managing `ListenerRule`s.
*
* If you have already deployed a `ListenerRule` using this method
* and need to migrate to using the more feature rich `addAction()`
* method, then you will need to set the `removeRuleSuffixFromLogicalId: true`
* property there to avoid having CloudFormation attempt to replace your resource.
*/
public addTargetGroups(id: string, props: AddApplicationTargetGroupsProps): void {
checkAddRuleProps(props);

if (props.priority !== undefined) {
const removeRuleSuffixFromLogicalId = props.removeRuleSuffixFromLogicalId ?? true;
const ruleId = removeRuleSuffixFromLogicalId ? id : id + 'Rule';
// New rule
new ApplicationListenerRule(this, ruleId, {
new ApplicationListenerRule(this, id, {
listener: this,
priority: props.priority,
...props,
Expand Down Expand Up @@ -686,7 +674,7 @@ abstract class ExternalApplicationListener extends Resource implements IApplicat
checkAddRuleProps(props);

if (props.priority !== undefined) {
const ruleId = props.removeRuleSuffixFromLogicalId ? id : id + 'Rule';
const ruleId = props.removeSuffix ? id : id + 'Rule';
// New rule
//
// TargetGroup.registerListener is called inside ApplicationListenerRule.
Expand Down Expand Up @@ -815,16 +803,6 @@ export interface AddApplicationTargetGroupsProps extends AddRuleProps {
* Target groups to forward requests to
*/
readonly targetGroups: IApplicationTargetGroup[];
/**
* `ListenerRule`s have a `Rule` suffix on their logicalId by default.
*
* Legacy behavior did not include the `Rule` suffix on the logicalId of the generated `ListenerRule`
* when generated by the `addTargetGroups()` method.
* This exists to allow new `ListenerRule`s to have consistent logicalIds.
*
* @default true remove the logicalId `Rule` suffix
*/
readonly removeRuleSuffixFromLogicalId?: boolean;
}

/**
Expand All @@ -847,7 +825,7 @@ export interface AddApplicationActionProps extends AddRuleProps {
*
* @default - use standard logicalId with the `Rule` suffix
*/
readonly removeRuleSuffixFromLogicalId?: boolean;
readonly removeSuffix?: boolean;
}

/**
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -1701,48 +1701,18 @@ describe('tests', () => {
describe('Rule suffix for logicalId', () => {
const identifierToken = 'SuperMagicToken';
interface TestCase {
readonly removeRuleSuffixFromLogicalId?: boolean;
readonly removeSuffix?: boolean;
readonly expectedLogicalId: string;
};
const nonDefaultTestCases: TestCase[] = [
{ removeRuleSuffixFromLogicalId: true, expectedLogicalId: identifierToken },
{ removeRuleSuffixFromLogicalId: false, expectedLogicalId: identifierToken + 'Rule' },
{ removeSuffix: true, expectedLogicalId: identifierToken },
{ removeSuffix: false, expectedLogicalId: identifierToken + 'Rule' },
];
test.each<TestCase>([
// Default is to not have the `Rule` suffix, per legacy behavior.
{ removeRuleSuffixFromLogicalId: undefined, expectedLogicalId: identifierToken },
...nonDefaultTestCases,
])('addTargetGroups %s', ({ removeRuleSuffixFromLogicalId, expectedLogicalId }) => {
// GIVEN
const app = new cdk.App();
const stack = new cdk.Stack(app, 'TestStack', { env: { account: '123456789012', region: 'us-east-1' } });
const vpc = new ec2.Vpc(stack, 'Stack');
const targetGroup = new elbv2.ApplicationTargetGroup(stack, 'TargetGroup', { vpc, port: 80 });
const listener = elbv2.ApplicationListener.fromLookup(stack, 'a', {
loadBalancerTags: {
some: 'tag',
},
});

// WHEN
listener.addTargetGroups(identifierToken, {
conditions: [elbv2.ListenerCondition.pathPatterns(['/fake'])],
priority: 42,
targetGroups: [targetGroup],
removeRuleSuffixFromLogicalId,
});

// THEN
const applicationListenerRule = listener.node.children.find((v)=> v.hasOwnProperty('conditions'));
expect(applicationListenerRule).toBeDefined();
expect(applicationListenerRule!.node.id).toBe(expectedLogicalId);
});

test.each<TestCase>([
// Default is consistent, which means it has the `Rule` suffix. This means no change from legacy behavior
{ removeRuleSuffixFromLogicalId: undefined, expectedLogicalId: identifierToken + 'Rule' },
{ removeSuffix: undefined, expectedLogicalId: identifierToken + 'Rule' },
...nonDefaultTestCases,
])('addAction %s', ({ removeRuleSuffixFromLogicalId, expectedLogicalId }) => {
])('addAction %s', ({ removeSuffix, expectedLogicalId }) => {
// GIVEN
const app = new cdk.App();
const stack = new cdk.Stack(app, 'TestStack', { env: { account: '123456789012', region: 'us-east-1' } });
Expand All @@ -1759,7 +1729,7 @@ describe('tests', () => {
action: elbv2.ListenerAction.weightedForward([{ targetGroup, weight: 1 }]),
conditions: [elbv2.ListenerCondition.pathPatterns(['/fake'])],
priority: 42,
removeRuleSuffixFromLogicalId,
removeSuffix,
});

// THEN
Expand Down

0 comments on commit 2186314

Please sign in to comment.