@aws-solutions-constructs/core
Version:
Core CDK Construct for patterns library
118 lines • 13.5 kB
JavaScript
"use strict";
/**
* Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"). You may not use this file except in compliance
* with the License. A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES
* OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
Object.defineProperty(exports, "__esModule", { value: true });
const aws_cdk_lib_1 = require("aws-cdk-lib");
const defaults = require("../");
const assertions_1 = require("aws-cdk-lib/assertions");
const ec2 = require("aws-cdk-lib/aws-ec2");
// --------------------------------------------------------------
// Test minimal deployment with no properties
// --------------------------------------------------------------
test("Test minimal deployment with no properties", () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
const vpc = new ec2.Vpc(stack, "test-vpc", {});
// Helper declaration
defaults.buildSecurityGroup(stack, "primary-queue", {
vpc,
allowAllOutbound: true,
}, [], []);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::EC2::SecurityGroup", {
SecurityGroupEgress: [
{
CidrIp: "0.0.0.0/0",
Description: "Allow all outbound traffic by default",
IpProtocol: "-1",
},
],
});
});
test("Test deployment with ingress rules", () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
const vpc = new ec2.Vpc(stack, "test-vpc", {});
// Helper declaration
defaults.buildSecurityGroup(stack, "primary-queue", {
vpc,
allowAllOutbound: true,
}, [{ peer: ec2.Peer.ipv4("1.1.1.1/16"), connection: ec2.Port.tcp(100) }], []);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::EC2::SecurityGroup", {
SecurityGroupIngress: [
{
CidrIp: "1.1.1.1/16",
Description: "from 1.1.1.1/16:100",
FromPort: 100,
IpProtocol: "tcp",
ToPort: 100,
},
],
});
});
test("Test deployment with egress rule", () => {
// Stack
const stack = new aws_cdk_lib_1.Stack();
const vpc = new ec2.Vpc(stack, "test-vpc", {});
// Helper declaration
defaults.buildSecurityGroup(stack, "primary-queue", {
vpc,
allowAllOutbound: false,
}, [], [
{ peer: ec2.Peer.ipv4("1.1.1.1/16"), connection: ec2.Port.tcp(100) },
{ peer: ec2.Peer.ipv4("2.2.2.2/24"), connection: ec2.Port.tcp(200) },
]);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::EC2::SecurityGroup", {
SecurityGroupEgress: [
{
CidrIp: "1.1.1.1/16",
Description: "from 1.1.1.1/16:100",
FromPort: 100,
IpProtocol: "tcp",
ToPort: 100,
},
{
CidrIp: "2.2.2.2/24",
Description: "from 2.2.2.2/24:200",
FromPort: 200,
IpProtocol: "tcp",
ToPort: 200,
},
],
});
});
test("Test self referencing security group", () => {
const testPort = 33333;
// Stack
const stack = new aws_cdk_lib_1.Stack();
const vpc = new ec2.Vpc(stack, "test-vpc", {});
// Helper declaration
defaults.CreateSelfReferencingSecurityGroup(stack, "testsg", vpc, testPort);
assertions_1.Template.fromStack(stack).hasResourceProperties("AWS::EC2::SecurityGroupIngress", {
IpProtocol: "TCP",
FromPort: testPort,
ToPort: testPort,
GroupId: {
"Fn::GetAtt": [
"testsgcachesg72A723EA",
"GroupId"
]
},
SourceSecurityGroupId: {
"Fn::GetAtt": [
"testsgcachesg72A723EA",
"GroupId"
]
},
});
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"security-group-helper.test.js","sourceRoot":"","sources":["security-group-helper.test.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;GAWG;;AAEH,6CAAoC;AACpC,gCAAgC;AAChC,uDAAkD;AAClD,2CAA2C;AAE3C,iEAAiE;AACjE,6CAA6C;AAC7C,iEAAiE;AACjE,IAAI,CAAC,4CAA4C,EAAE,GAAG,EAAE;IACtD,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAE/C,qBAAqB;IACrB,QAAQ,CAAC,kBAAkB,CACzB,KAAK,EACL,eAAe,EACf;QACE,GAAG;QACH,gBAAgB,EAAE,IAAI;KACvB,EACD,EAAE,EACF,EAAE,CACH,CAAC;IAEF,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,yBAAyB,EAAE;QACzE,mBAAmB,EAAE;YACnB;gBACE,MAAM,EAAE,WAAW;gBACnB,WAAW,EAAE,uCAAuC;gBACpD,UAAU,EAAE,IAAI;aACjB;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,oCAAoC,EAAE,GAAG,EAAE;IAC9C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAE/C,qBAAqB;IACrB,QAAQ,CAAC,kBAAkB,CACzB,KAAK,EACL,eAAe,EACf;QACE,GAAG;QACH,gBAAgB,EAAE,IAAI;KACvB,EACD,CAAC,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,UAAU,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,EACtE,EAAE,CACH,CAAC;IAEF,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,yBAAyB,EAAE;QACzE,oBAAoB,EAAE;YACpB;gBACE,MAAM,EAAE,YAAY;gBACpB,WAAW,EAAE,qBAAqB;gBAClC,QAAQ,EAAE,GAAG;gBACb,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,GAAG;aACZ;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,kCAAkC,EAAE,GAAG,EAAE;IAC5C,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAE/C,qBAAqB;IACrB,QAAQ,CAAC,kBAAkB,CACzB,KAAK,EACL,eAAe,EACf;QACE,GAAG;QACH,gBAAgB,EAAE,KAAK;KACxB,EACD,EAAE,EACF;QACE,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,UAAU,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;QACpE,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,UAAU,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;KACrE,CACF,CAAC;IAEF,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,yBAAyB,EAAE;QACzE,mBAAmB,EAAE;YACnB;gBACE,MAAM,EAAE,YAAY;gBACpB,WAAW,EAAE,qBAAqB;gBAClC,QAAQ,EAAE,GAAG;gBACb,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,GAAG;aACZ;YACD;gBACE,MAAM,EAAE,YAAY;gBACpB,WAAW,EAAE,qBAAqB;gBAClC,QAAQ,EAAE,GAAG;gBACb,UAAU,EAAE,KAAK;gBACjB,MAAM,EAAE,GAAG;aACZ;SACF;KACF,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,sCAAsC,EAAE,GAAG,EAAE;IAChD,MAAM,QAAQ,GAAG,KAAK,CAAC;IACvB,QAAQ;IACR,MAAM,KAAK,GAAG,IAAI,mBAAK,EAAE,CAAC;IAE1B,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC,CAAC;IAE/C,qBAAqB;IACrB,QAAQ,CAAC,kCAAkC,CACzC,KAAK,EACL,QAAQ,EACR,GAAG,EACH,QAAQ,CACT,CAAC;IAEF,qBAAQ,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,qBAAqB,CAAC,gCAAgC,EAAE;QAChF,UAAU,EAAE,KAAK;QACjB,QAAQ,EAAE,QAAQ;QAClB,MAAM,EAAE,QAAQ;QAChB,OAAO,EAAE;YACP,YAAY,EAAE;gBACZ,uBAAuB;gBACvB,SAAS;aACV;SACF;QACD,qBAAqB,EAAE;YACrB,YAAY,EAAE;gBACZ,uBAAuB;gBACvB,SAAS;aACV;SACF;KACF,CAAC,CAAC;AAEL,CAAC,CAAC,CAAC","sourcesContent":["/**\n *  Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.\n *\n *  Licensed under the Apache License, Version 2.0 (the \"License\"). You may not use this file except in compliance\n *  with the License. A copy of the License is located at\n *\n *      http://www.apache.org/licenses/LICENSE-2.0\n *\n *  or in the 'license' file accompanying this file. This file is distributed on an 'AS IS' BASIS, WITHOUT WARRANTIES\n *  OR CONDITIONS OF ANY KIND, express or implied. See the License for the specific language governing permissions\n *  and limitations under the License.\n */\n\nimport { Stack } from \"aws-cdk-lib\";\nimport * as defaults from \"../\";\nimport { Template } from 'aws-cdk-lib/assertions';\nimport * as ec2 from \"aws-cdk-lib/aws-ec2\";\n\n// --------------------------------------------------------------\n// Test minimal deployment with no properties\n// --------------------------------------------------------------\ntest(\"Test minimal deployment with no properties\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const vpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  defaults.buildSecurityGroup(\n    stack,\n    \"primary-queue\",\n    {\n      vpc,\n      allowAllOutbound: true,\n    },\n    [],\n    []\n  );\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::EC2::SecurityGroup\", {\n    SecurityGroupEgress: [\n      {\n        CidrIp: \"0.0.0.0/0\",\n        Description: \"Allow all outbound traffic by default\",\n        IpProtocol: \"-1\",\n      },\n    ],\n  });\n});\n\ntest(\"Test deployment with ingress rules\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const vpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  defaults.buildSecurityGroup(\n    stack,\n    \"primary-queue\",\n    {\n      vpc,\n      allowAllOutbound: true,\n    },\n    [{ peer: ec2.Peer.ipv4(\"1.1.1.1/16\"), connection: ec2.Port.tcp(100) }],\n    []\n  );\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::EC2::SecurityGroup\", {\n    SecurityGroupIngress: [\n      {\n        CidrIp: \"1.1.1.1/16\",\n        Description: \"from 1.1.1.1/16:100\",\n        FromPort: 100,\n        IpProtocol: \"tcp\",\n        ToPort: 100,\n      },\n    ],\n  });\n});\n\ntest(\"Test deployment with egress rule\", () => {\n  // Stack\n  const stack = new Stack();\n\n  const vpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  defaults.buildSecurityGroup(\n    stack,\n    \"primary-queue\",\n    {\n      vpc,\n      allowAllOutbound: false,\n    },\n    [],\n    [\n      { peer: ec2.Peer.ipv4(\"1.1.1.1/16\"), connection: ec2.Port.tcp(100) },\n      { peer: ec2.Peer.ipv4(\"2.2.2.2/24\"), connection: ec2.Port.tcp(200) },\n    ]\n  );\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::EC2::SecurityGroup\", {\n    SecurityGroupEgress: [\n      {\n        CidrIp: \"1.1.1.1/16\",\n        Description: \"from 1.1.1.1/16:100\",\n        FromPort: 100,\n        IpProtocol: \"tcp\",\n        ToPort: 100,\n      },\n      {\n        CidrIp: \"2.2.2.2/24\",\n        Description: \"from 2.2.2.2/24:200\",\n        FromPort: 200,\n        IpProtocol: \"tcp\",\n        ToPort: 200,\n      },\n    ],\n  });\n});\n\ntest(\"Test self referencing security group\", () => {\n  const testPort = 33333;\n  // Stack\n  const stack = new Stack();\n\n  const vpc = new ec2.Vpc(stack, \"test-vpc\", {});\n\n  // Helper declaration\n  defaults.CreateSelfReferencingSecurityGroup(\n    stack,\n    \"testsg\",\n    vpc,\n    testPort,\n  );\n\n  Template.fromStack(stack).hasResourceProperties(\"AWS::EC2::SecurityGroupIngress\", {\n    IpProtocol: \"TCP\",\n    FromPort: testPort,\n    ToPort: testPort,\n    GroupId: {\n      \"Fn::GetAtt\": [\n        \"testsgcachesg72A723EA\",\n        \"GroupId\"\n      ]\n    },\n    SourceSecurityGroupId: {\n      \"Fn::GetAtt\": [\n        \"testsgcachesg72A723EA\",\n        \"GroupId\"\n      ]\n    },\n  });\n\n});\n"]}