Skip to content

Commit

Permalink
fix: Update GuClassicLoadBalancer with revised logicalId logic
Browse files Browse the repository at this point in the history
In #364 we placed the logic of overriding a construct's logicalId into a single place.

In this change, we're updating the `GuClassicLoadBalancer` construct to adopt the new logic. As of #418 it's as simple as using the `GuStatefulMigratableConstruct` mixin!
  • Loading branch information
akash1810 committed Apr 13, 2021
1 parent 73ef8ec commit 0d0eba7
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 31 deletions.
35 changes: 10 additions & 25 deletions src/constructs/loadbalancing/elb.test.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import "@aws-cdk/assert/jest";
import "../../utils/test/jest";
import { SynthUtils } from "@aws-cdk/assert/lib/synth-utils";
import { Vpc } from "@aws-cdk/aws-ec2";
import { Stack } from "@aws-cdk/core";
Expand All @@ -14,43 +15,27 @@ describe("The GuClassicLoadBalancer class", () => {
privateSubnetIds: [""],
});

test("overrides the id with the overrideId prop", () => {
const stack = simpleGuStackForTesting();
new GuClassicLoadBalancer(stack, "ClassicLoadBalancer", { vpc, overrideId: true });
test("overrides the logicalId when existingLogicalId is set in a migrating stack", () => {
const stack = simpleGuStackForTesting({ migratedFromCloudFormation: true });
new GuClassicLoadBalancer(stack, "ClassicLoadBalancer", { vpc, existingLogicalId: "MyCLB" });

const json = SynthUtils.toCloudFormation(stack) as SynthedStack;
expect(Object.keys(json.Resources)).toContain("ClassicLoadBalancer");
expect(stack).toHaveResourceOfTypeAndLogicalId("AWS::ElasticLoadBalancing::LoadBalancer", "MyCLB");
});

test("has an auto-generated ID by default", () => {
test("auto-generates the logicalId by default", () => {
const stack = simpleGuStackForTesting();
new GuClassicLoadBalancer(stack, "ClassicLoadBalancer", { vpc });

const json = SynthUtils.toCloudFormation(stack) as SynthedStack;
expect(Object.keys(json.Resources)).not.toContain("ClassicLoadBalancer");
});

test("overrides the id if the stack migrated value is true", () => {
const stack = simpleGuStackForTesting({ migratedFromCloudFormation: true });
new GuClassicLoadBalancer(stack, "ClassicLoadBalancer", { vpc });

const json = SynthUtils.toCloudFormation(stack) as SynthedStack;
expect(Object.keys(json.Resources)).toContain("ClassicLoadBalancer");
});

test("does not override the id if the stack migrated value is true but the override id value is false", () => {
const stack = simpleGuStackForTesting({ migratedFromCloudFormation: true });
new GuClassicLoadBalancer(stack, "ClassicLoadBalancer", { vpc, overrideId: false });

const json = SynthUtils.toCloudFormation(stack) as SynthedStack;
expect(Object.keys(json.Resources)).not.toContain("ClassicLoadBalancer");
expect(stack).toHaveResourceOfTypeAndLogicalId(
"AWS::ElasticLoadBalancing::LoadBalancer",
/^ClassicLoadBalancer.+$/
);
});

test("overrides any properties as required", () => {
const stack = simpleGuStackForTesting();
new GuClassicLoadBalancer(stack, "ClassicLoadBalancer", {
vpc,
overrideId: true,
propertiesToOverride: {
AccessLoggingPolicy: {
EmitInterval: 5,
Expand Down
10 changes: 4 additions & 6 deletions src/constructs/loadbalancing/elb.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,16 +6,17 @@ import type {
} from "@aws-cdk/aws-elasticloadbalancing";
import { LoadBalancer, LoadBalancingProtocol } from "@aws-cdk/aws-elasticloadbalancing";
import { Duration } from "@aws-cdk/core";
import { GuStatefulMigratableConstruct } from "../../utils/mixin";
import type { GuStack } from "../core";
import { GuArnParameter } from "../core";
import type { GuMigratingResource } from "../core/migrating";

interface GuClassicLoadBalancerProps extends Omit<LoadBalancerProps, "healthCheck"> {
overrideId?: boolean;
interface GuClassicLoadBalancerProps extends Omit<LoadBalancerProps, "healthCheck">, GuMigratingResource {
propertiesToOverride?: Record<string, unknown>;
healthCheck?: Partial<HealthCheck>;
}

export class GuClassicLoadBalancer extends LoadBalancer {
export class GuClassicLoadBalancer extends GuStatefulMigratableConstruct(LoadBalancer) {
static DefaultHealthCheck = {
port: 9000,
path: "/healthcheck",
Expand All @@ -36,9 +37,6 @@ export class GuClassicLoadBalancer extends LoadBalancer {

const cfnLb = this.node.defaultChild as CfnLoadBalancer;

if (mergedProps.overrideId || (scope.migratedFromCloudFormation && mergedProps.overrideId !== false))
cfnLb.overrideLogicalId(id);

mergedProps.propertiesToOverride &&
Object.entries(mergedProps.propertiesToOverride).forEach(([key, value]) => cfnLb.addPropertyOverride(key, value));
}
Expand Down

0 comments on commit 0d0eba7

Please sign in to comment.