diff --git a/CHANGELOG.md b/CHANGELOG.md index e2b3b4b6c..95a754f43 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,14 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. +## [2.39.0](https://github.com/awslabs/aws-solutions-constructs/compare/v2.38.0...v2.39.0) (2023-04-23) + +Built on CDK v2.76.0 + +### Bug Fixes + +* **aws-*-stepfunctions:** generate stack specific physical log group name ([#945](https://github.com/awslabs/aws-solutions-constructs/issues/945)) ([3e46579](https://github.com/awslabs/aws-solutions-constructs/commit/3e46579ef02e726143cf437be293c9435d013f5f)) + ## [2.38.0](https://github.com/awslabs/aws-solutions-constructs/compare/v2.37.0...v2.38.0) (2023-04-16) Build on CDK v2.74.0 diff --git a/deployment/v2/align-version.js b/deployment/v2/align-version.js index 4b61a5c8e..4550e8a5c 100755 --- a/deployment/v2/align-version.js +++ b/deployment/v2/align-version.js @@ -10,7 +10,7 @@ const findVersion = process.argv[2]; const replaceVersion = process.argv[3]; // these versions need to be sourced from a config file -const awsCdkLibVersion = '2.74.0'; +const awsCdkLibVersion = '2.76.0'; const constructsVersion = '10.0.0'; const MODULE_EXEMPTIONS = new Set([ '@aws-cdk/cloudformation-diff', diff --git a/source/lerna.json b/source/lerna.json index 84db77c3f..adddd0b92 100644 --- a/source/lerna.json +++ b/source/lerna.json @@ -6,5 +6,5 @@ "./patterns/@aws-solutions-constructs/*" ], "rejectCycles": "true", - "version": "2.38.0" + "version": "2.39.0" } diff --git a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.additional-request-templates.expected.json b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.additional-request-templates.expected.json index 140df25ef..b25627113 100644 --- a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.additional-request-templates.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.additional-request-templates.expected.json @@ -560,9 +560,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } } diff --git a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.apigateway-kinesis-overwrite.expected.json b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.apigateway-kinesis-overwrite.expected.json index 5a145e8cf..4cb3f8ff3 100644 --- a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.apigateway-kinesis-overwrite.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.apigateway-kinesis-overwrite.expected.json @@ -512,9 +512,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } } diff --git a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.custom-integration-responses.expected.json b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.custom-integration-responses.expected.json index 32f03b4dd..4ead90e0f 100644 --- a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.custom-integration-responses.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.custom-integration-responses.expected.json @@ -544,9 +544,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } } diff --git a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.no-arguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.no-arguments.expected.json index dc2d2b399..c59473e94 100644 --- a/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.no-arguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-apigateway-kinesisstreams/test/integ.no-arguments.expected.json @@ -548,9 +548,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } } diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing-eventbus.expected.json b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing-eventbus.expected.json index 77a6a13df..8ac3c17b4 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing-eventbus.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing-eventbus.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing.expected.json b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing.expected.json index 33310bf83..7b52073cf 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-existing.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-new-eventbus.expected.json b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-new-eventbus.expected.json index 2eb34602b..188654d1b 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-new-eventbus.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-new-eventbus.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-no-arguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-no-arguments.expected.json index 5e0e7631c..62961abd1 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-no-arguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-kinesisstreams/test/integ.eventbridge-kinesisstreams-no-arguments.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/eventbridge-stepfunctions.test.ts b/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/eventbridge-stepfunctions.test.ts index 31e00a159..6c6eb9c2c 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/eventbridge-stepfunctions.test.ts +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/eventbridge-stepfunctions.test.ts @@ -197,28 +197,3 @@ test('check custom event bus resource with props when deploy:true', () => { Name: 'testcustomeventbus' }); }); - -test('check LogGroup name', () => { - const stack = new cdk.Stack(); - - deployNewStateMachine(stack); - - // Perform some fancy stuff to examine the specifics of the LogGroupName - const expectedPrefix = '/aws/vendedlogs/states/constructs/'; - const lengthOfDatetimeSuffix = 13; - - const template = Template.fromStack(stack); - const LogGroup = template.findResources("AWS::Logs::LogGroup"); - - const logName = LogGroup.testeventbridgestepfunctionsStateMachineLogGroup826A5B74.Properties.LogGroupName; - const suffix = logName.slice(-lengthOfDatetimeSuffix); - - // Look for the expected Prefix and the 13 digit time suffix - expect(logName.slice(0, expectedPrefix.length)).toEqual(expectedPrefix); - expect(IsWholeNumber(suffix)).not.toBe(false); -}); - -function IsWholeNumber(target: string): boolean { - const numberPattern = /[0-9]{13}/; - return target.match(numberPattern) !== null; -} diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.expected.json b/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.expected.json index 0c108fa64..bb8778950 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.expected.json @@ -3,7 +3,27 @@ "testeventbridgestepfunctionsconstructStateMachineLogGroup3098B32C": { "Type": "AWS::Logs::LogGroup", "Properties": { - "LogGroupName": "integ-test-no-arguments" + "LogGroupName": { + "Fn::Join": [ + "", + [ + "/aws/vendedlogs/states/constructs/eventbridge-stepfunctions-no-argumenttest-eventbridge-stepfunctions-constructStateMachineLog-", + { + "Fn::Select": [ + 2, + { + "Fn::Split": [ + "/", + { + "Ref": "AWS::StackId" + } + ] + } + ] + } + ] + ] + } }, "UpdateReplacePolicy": "Delete", "DeletionPolicy": "Delete", diff --git a/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.ts b/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.ts index cd487eaa8..9d43105b1 100644 --- a/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.ts +++ b/source/patterns/@aws-solutions-constructs/aws-eventbridge-stepfunctions/test/integ.eventbridge-stepfunctions-no-argument.ts @@ -33,7 +33,6 @@ const props: EventbridgeToStepfunctionsProps = { }, logGroupProps: { removalPolicy: RemovalPolicy.DESTROY, - logGroupName: "integ-test-no-arguments" }, }; diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingFargateService.expected.json b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingFargateService.expected.json index e5757b1b2..810cc8994 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingFargateService.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingFargateService.expected.json @@ -1120,9 +1120,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingVpc.expected.json b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingVpc.expected.json index 52c6e4a16..bc14d2b5a 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingVpc.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.existingVpc.expected.json @@ -841,9 +841,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.fargateServiceFromProps.expected.json b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.fargateServiceFromProps.expected.json index b1e6e1296..b24e7d147 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.fargateServiceFromProps.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.fargateServiceFromProps.expected.json @@ -8,9 +8,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.noArguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.noArguments.expected.json index b174eb3c8..62dd5c4b3 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.noArguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.noArguments.expected.json @@ -8,9 +8,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.vpcFromProps.expected.json b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.vpcFromProps.expected.json index f46abc294..d12c25b61 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.vpcFromProps.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-kinesisstreams/test/integ.vpcFromProps.expected.json @@ -8,9 +8,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/fargate-stepfunctions.test.ts b/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/fargate-stepfunctions.test.ts index e33e2461b..c265b78ec 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/fargate-stepfunctions.test.ts +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/fargate-stepfunctions.test.ts @@ -321,29 +321,3 @@ function testStateMachineProps(stack: cdk.Stack, userProps?: stepfunctions.State return defaults.consolidateProps(defaultTestProp, userProps); } - -test('check LogGroup name', () => { - const stack = new cdk.Stack(); - const publicApi = true; - - createFargateConstructWithNewResources(stack, publicApi); - - // Perform some fancy stuff to examine the specifics of the LogGroupName - const expectedPrefix = '/aws/vendedlogs/states/constructs/'; - const lengthOfDatetimeSuffix = 13; - - const template = Template.fromStack(stack); - const LogGroup = template.findResources("AWS::Logs::LogGroup"); - - const logName = LogGroup.testconstructStateMachineLogGroup2EB4F48B.Properties.LogGroupName; - const suffix = logName.slice(-lengthOfDatetimeSuffix); - - // Look for the expected Prefix and the 13 digit time suffix - expect(logName.slice(0, expectedPrefix.length)).toEqual(expectedPrefix); - expect(IsWholeNumber(suffix)).not.toBe(false); -}); - -function IsWholeNumber(target: string): boolean { - const numberPattern = /[0-9]{13}/; - return target.match(numberPattern) !== null; -} diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.expected.json b/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.expected.json index 2c7a36d6d..f8b2fa26e 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.expected.json @@ -1076,7 +1076,27 @@ "testconstructStateMachineLogGroup2EB4F48B": { "Type": "AWS::Logs::LogGroup", "Properties": { - "LogGroupName": "with-lambda" + "LogGroupName": { + "Fn::Join": [ + "", + [ + "/aws/vendedlogs/states/constructs/new-resourcestest-constructStateMachineLog-", + { + "Fn::Select": [ + 2, + { + "Fn::Split": [ + "/", + { + "Ref": "AWS::StackId" + } + ] + } + ] + } + ] + ] + } }, "UpdateReplacePolicy": "Delete", "DeletionPolicy": "Delete", diff --git a/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.ts b/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.ts index 45619476f..3543ba05f 100644 --- a/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.ts +++ b/source/patterns/@aws-solutions-constructs/aws-fargate-stepfunctions/test/integ.new-resources.ts @@ -50,7 +50,6 @@ const constructProps: FargateToStepfunctionsProps = { stateMachineEnvironmentVariableName: 'CUSTOM_NAME', logGroupProps: { removalPolicy: RemovalPolicy.DESTROY, - logGroupName: "with-lambda" } }; diff --git a/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.existing-kinesisstream.expected.json b/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.existing-kinesisstream.expected.json index 25e5e1a00..2486dfc92 100644 --- a/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.existing-kinesisstream.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.existing-kinesisstream.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.new-kinesisstream.expected.json b/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.new-kinesisstream.expected.json index b585dff9c..c2e180e81 100644 --- a/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.new-kinesisstream.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.new-kinesisstream.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.no-arguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.no-arguments.expected.json index d908110cb..cecdc54ec 100644 --- a/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.no-arguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-iot-kinesisstreams/test/integ.no-arguments.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.code-asset-job.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.code-asset-job.expected.json index 705c0fe01..f7039123d 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.code-asset-job.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.code-asset-job.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.existing-job.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.existing-job.expected.json index 1ae8f0317..6910e303d 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.existing-job.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.existing-job.expected.json @@ -89,9 +89,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.no-arguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.no-arguments.expected.json index f18b6a9c1..b11db6096 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.no-arguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-gluejob/test/integ.no-arguments.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.customLoggingBucket.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.customLoggingBucket.expected.json index 2fbc46ba6..17ba9aba0 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.customLoggingBucket.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.customLoggingBucket.expected.json @@ -8,9 +8,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-bucket.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-bucket.expected.json index dc35eb138..01616e5c9 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-bucket.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-bucket.expected.json @@ -46,9 +46,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-logging-bucket.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-logging-bucket.expected.json index 94197fb35..b0ac9581b 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-logging-bucket.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existing-logging-bucket.expected.json @@ -47,9 +47,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existingStreamObj.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existingStreamObj.expected.json index d533ff8b8..1fe2510bc 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existingStreamObj.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.existingStreamObj.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.no-arguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.no-arguments.expected.json index 8b46f7bdb..cc69403ef 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.no-arguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-kinesisfirehose-s3/test/integ.no-arguments.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.existing.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.existing.expected.json index 54790562d..a3f9dfb48 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.existing.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.existing.expected.json @@ -189,9 +189,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.no-arguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.no-arguments.expected.json index e706fe3a2..cf6bffe41 100644 --- a/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.no-arguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-kinesisstreams-lambda/test/integ.no-arguments.expected.json @@ -9,9 +9,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingLambda.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingLambda.expected.json index c86be015d..7ebdbedd1 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingLambda.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingLambda.expected.json @@ -162,9 +162,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingStreamWithCmk.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingStreamWithCmk.expected.json index a680ce63a..9bb8057c1 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingStreamWithCmk.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingStreamWithCmk.expected.json @@ -49,9 +49,6 @@ "Arn" ] } - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingVpc.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingVpc.expected.json index 69d3f04b0..cef2eab71 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingVpc.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.existingVpc.expected.json @@ -940,9 +940,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpc.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpc.expected.json index 9eb5c221e..7f798590d 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpc.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpc.expected.json @@ -227,9 +227,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpcFromProps.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpcFromProps.expected.json index 63776674e..fd977a1d1 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpcFromProps.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.newVpcFromProps.expected.json @@ -219,9 +219,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.noArguments.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.noArguments.expected.json index 7f7097d3f..c79909567 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.noArguments.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-kinesisstreams/test/integ.noArguments.expected.json @@ -162,9 +162,6 @@ "StreamEncryption": { "EncryptionType": "KMS", "KeyId": "alias/aws/kinesis" - }, - "StreamModeDetails": { - "StreamMode": "PROVISIONED" } } }, diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.expected.json b/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.expected.json index cf8519009..5d32965b4 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.expected.json @@ -3,7 +3,27 @@ "testlambdastepfunctionsconstructStateMachineLogGroup1FD4C0D4": { "Type": "AWS::Logs::LogGroup", "Properties": { - "LogGroupName": "with-lambda" + "LogGroupName": { + "Fn::Join": [ + "", + [ + "/aws/vendedlogs/states/constructs/deploy-lambdatest-lambda-stepfunctions-constructStateMachineLog-", + { + "Fn::Select": [ + 2, + { + "Fn::Split": [ + "/", + { + "Ref": "AWS::StackId" + } + ] + } + ] + } + ] + ] + } }, "UpdateReplacePolicy": "Delete", "DeletionPolicy": "Delete", diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.ts b/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.ts index 7bf44dcb1..d1578b19e 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.ts +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/integ.deploy-lambda.ts @@ -37,7 +37,6 @@ const props: LambdaToStepfunctionsProps = { }, logGroupProps: { removalPolicy: RemovalPolicy.DESTROY, - logGroupName: "with-lambda" } }; diff --git a/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/lambda-stepfunctions.test.ts b/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/lambda-stepfunctions.test.ts index 040fdc55c..cf9fbc33b 100644 --- a/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/lambda-stepfunctions.test.ts +++ b/source/patterns/@aws-solutions-constructs/aws-lambda-stepfunctions/test/lambda-stepfunctions.test.ts @@ -469,41 +469,3 @@ test("Test bad call with existingVpc and deployVpc", () => { // Assertion expect(app).toThrowError(); }); - -test('check LogGroup name', () => { - // Stack - const stack = new Stack(); - // Helper declaration - const startState = new stepfunctions.Pass(stack, 'StartState'); - new LambdaToStepfunctions(stack, 'lambda-to-step-function-stack', { - lambdaFunctionProps: { - runtime: lambda.Runtime.NODEJS_16_X, - handler: 'index.handler', - code: lambda.Code.fromAsset(`${__dirname}/lambda`), - environment: { - LAMBDA_NAME: 'existing-function' - } - }, - stateMachineProps: { - definition: startState - } - }); - // Perform some fancy stuff to examine the specifics of the LogGroupName - const expectedPrefix = '/aws/vendedlogs/states/constructs/'; - const lengthOfDatetimeSuffix = 13; - - const template = Template.fromStack(stack); - const LogGroup = template.findResources("AWS::Logs::LogGroup"); - - const logName = LogGroup.lambdatostepfunctionstackStateMachineLogGroupEAD4854E.Properties.LogGroupName; - const suffix = logName.slice(-lengthOfDatetimeSuffix); - - // Look for the expected Prefix and the 13 digit time suffix - expect(logName.slice(0, expectedPrefix.length)).toEqual(expectedPrefix); - expect(IsWholeNumber(suffix)).not.toBe(false); -}); - -function IsWholeNumber(target: string): boolean { - const numberPattern = /[0-9]{13}/; - return target.match(numberPattern) !== null; -} diff --git a/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.expected.json b/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.expected.json index 456f580d9..c2d6d28e0 100644 --- a/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.expected.json +++ b/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.expected.json @@ -116,7 +116,27 @@ "tests3stepfunctionsconstructtests3stepfunctionsconstructeventrulestepfunctionconstructStateMachineLogGroupE86C2CF5": { "Type": "AWS::Logs::LogGroup", "Properties": { - "LogGroupName": "with-lambda" + "LogGroupName": { + "Fn::Join": [ + "", + [ + "/aws/vendedlogs/states/constructs/s3-stepfunctions-no-argumenttest-s3-stepfunctions-construct-event-rule-step-function-constructStateMachineLog-", + { + "Fn::Select": [ + 2, + { + "Fn::Split": [ + "/", + { + "Ref": "AWS::StackId" + } + ] + } + ] + } + ] + ] + } }, "UpdateReplacePolicy": "Delete", "DeletionPolicy": "Delete", diff --git a/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.ts b/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.ts index 184941c9d..e79e25c07 100644 --- a/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.ts +++ b/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/integ.s3-stepfunctions-no-argument.ts @@ -33,7 +33,6 @@ const props: S3ToStepfunctionsProps = { }, logGroupProps: { removalPolicy: RemovalPolicy.DESTROY, - logGroupName: "with-lambda" }, logS3AccessLogs: false }; diff --git a/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/s3-stepfunctions.test.ts b/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/s3-stepfunctions.test.ts index c4cd1a914..927f09213 100644 --- a/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/s3-stepfunctions.test.ts +++ b/source/patterns/@aws-solutions-constructs/aws-s3-stepfunctions/test/s3-stepfunctions.test.ts @@ -191,28 +191,3 @@ test('s3 bucket with no logging bucket', () => { template.hasResourceProperties("Custom::S3BucketNotifications", {}); expect(construct.s3LoggingBucket).toEqual(undefined); }); - -test('check LogGroup name', () => { - const stack = new cdk.Stack(); - - deployNewStateMachine(stack); - - // Perform some fancy stuff to examine the specifics of the LogGroupName - const expectedPrefix = '/aws/vendedlogs/states/constructs/'; - const lengthOfDatetimeSuffix = 13; - - const template = Template.fromStack(stack); - const LogGroup = template.findResources("AWS::Logs::LogGroup"); - - const logName = LogGroup.tests3stepfunctionstests3stepfunctionseventrulestepfunctionconstructStateMachineLogGroupB4555776.Properties.LogGroupName; - const suffix = logName.slice(-lengthOfDatetimeSuffix); - - // Look for the expected Prefix and the 13 digit time suffix - expect(logName.slice(0, expectedPrefix.length)).toEqual(expectedPrefix); - expect(IsWholeNumber(suffix)).not.toBe(false); -}); - -function IsWholeNumber(target: string): boolean { - const numberPattern = /[0-9]{13}/; - return target.match(numberPattern) !== null; -} diff --git a/source/patterns/@aws-solutions-constructs/core/lib/step-function-helper.ts b/source/patterns/@aws-solutions-constructs/core/lib/step-function-helper.ts index ea62e10a8..8ae409523 100644 --- a/source/patterns/@aws-solutions-constructs/core/lib/step-function-helper.ts +++ b/source/patterns/@aws-solutions-constructs/core/lib/step-function-helper.ts @@ -21,7 +21,7 @@ import * as logs from 'aws-cdk-lib/aws-logs'; import * as cdk from 'aws-cdk-lib'; import * as smDefaults from './step-function-defaults'; import * as sfn from 'aws-cdk-lib/aws-stepfunctions'; -import { overrideProps, generateResourceName, addCfnSuppressRules } from './utils'; +import { overrideProps, addCfnSuppressRules, generatePhysicalName } from './utils'; import * as iam from 'aws-cdk-lib/aws-iam'; import * as cloudwatch from 'aws-cdk-lib/aws-cloudwatch'; import { buildLogGroup } from './cloudwatch-log-group-helper'; @@ -59,16 +59,18 @@ export function buildStateMachine(scope: Construct, stateMachineProps: sfn.State if (!consolidatedLogGroupProps) { consolidatedLogGroupProps = {}; } + + const maxLogGroupNameLength = 255; if (!consolidatedLogGroupProps?.logGroupName) { const logGroupPrefix = '/aws/vendedlogs/states/constructs/'; - const maxResourceNameLength = 255 - logGroupPrefix.length; + const maxGeneratedNameLength = maxLogGroupNameLength - logGroupPrefix.length; const nameParts: string[] = [ cdk.Stack.of(scope).stackName, // Name of the stack scope.node.id, // Construct ID 'StateMachineLog' // Literal string for log group name portion ]; - const logGroupName = logGroupPrefix + generateResourceName(nameParts, maxResourceNameLength, true); + const logGroupName = generatePhysicalName(logGroupPrefix, nameParts, maxGeneratedNameLength); consolidatedLogGroupProps = overrideProps(consolidatedLogGroupProps, { logGroupName }); } diff --git a/source/patterns/@aws-solutions-constructs/core/lib/utils.ts b/source/patterns/@aws-solutions-constructs/core/lib/utils.ts index 2b13ad0ed..6789d9cbb 100644 --- a/source/patterns/@aws-solutions-constructs/core/lib/utils.ts +++ b/source/patterns/@aws-solutions-constructs/core/lib/utils.ts @@ -104,7 +104,9 @@ export function printWarning(message: string) { /** * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. * - * @summary Creates a resource name in the style of the CDK (string+hash) + * @summary Creates a resource name in the style of the CDK (string+hash) - this value should be used for logical IDs, but + * not Physical Names, as it will not be static within a single stack instance lifetime, or it will not be different in + * different stack instances * @param {string[]} parts - the various string components of the name (eg - stackName, solutions construct ID, L2 construct ID) * @param {number} maxLength - the longest string that can be returned * @returns {string} - a string with concatenated parts (truncated if neccessary) + a hash of the full concatenated parts @@ -135,6 +137,49 @@ export function generateResourceName( return finalName.toLowerCase(); } +/** + * @internal This is an internal core function and should not be called directly by Solutions Constructs clients. + * + * @summary Creates a physical resource name in the style of the CDK (string+hash) - this value incorporates Stack ID, + * so it will remain static in multiple updates of a single stack, but will be different in a separate stack instance + * @param {string[]} parts - the various string components of the name (eg - stackName, solutions construct ID, L2 construct ID) + * @param {number} maxLength - the longest string that can be returned + * @returns {string} - a string with concatenated parts (truncated if neccessary) + a hash of the full concatenated parts + * + */ +export function generatePhysicalName( + prefix: string, + parts: string[], + maxLength: number, +): string { + // The result will consist of: + // -The prefix - unaltered + // -The parts concatenated, but reduced in size to meet the maxLength limit for the overall name + // -A hyphen delimiter + // -The GUID portion of the stack arn + + const stackIdGuidLength = 36; + const prefixLength = prefix.length; + const maxPartsLength = maxLength - prefixLength - 1 - stackIdGuidLength; // 1 is the hyphen + + // Extract the Stack ID Guid + const uniqueStackIdPart = cdk.Fn.select(2, cdk.Fn.split('/', `${cdk.Aws.STACK_ID}`)); + + let allParts: string = ''; + + parts.forEach((part) => { + allParts += part; + }); + + if (allParts.length > maxPartsLength) { + const subStringLength = maxPartsLength / 2; + allParts = allParts.substring(0, subStringLength) + allParts.substring(allParts.length - subStringLength); + } + + const finalName = prefix.toLowerCase() + allParts + '-' + uniqueStackIdPart; + return finalName; +} + /** * Removes all non-alphanumeric characters in a string. */ diff --git a/source/patterns/@aws-solutions-constructs/core/test/step-function-helper.test.ts b/source/patterns/@aws-solutions-constructs/core/test/step-function-helper.test.ts index 4de810912..001858ac2 100644 --- a/source/patterns/@aws-solutions-constructs/core/test/step-function-helper.test.ts +++ b/source/patterns/@aws-solutions-constructs/core/test/step-function-helper.test.ts @@ -194,7 +194,7 @@ test('Test deployment with custom role', () => { test('Confirm format of name', () => { // Stack - const stack = new Stack(); + const stack = new Stack(undefined, 'teststack'); // Step function definition const startState = new sfn.Pass(stack, 'StartState'); // Build state machine @@ -211,19 +211,10 @@ test('Confirm format of name', () => { }); // Perform some fancy stuff to examine the specifics of the LogGroupName - const expectedPrefix = '/aws/vendedlogs/states/constructs/'; - const lengthOfDatetimeSuffix = 13; - const LogGroup = template.findResources("AWS::Logs::LogGroup"); const logName = LogGroup.StateMachineLogGroup15B91BCB.Properties.LogGroupName; - const suffix = logName.slice(-lengthOfDatetimeSuffix); - // Look for the expected Prefix and the 13 digit time suffix - expect(logName.slice(0, expectedPrefix.length)).toEqual(expectedPrefix); - expect(IsWholeNumber(suffix)).not.toBe(false); + expect(logName['Fn::Join']).toBeDefined(); + expect(logName['Fn::Join'].length).toEqual(2); + expect(logName['Fn::Join'][1][1]['Fn::Select'][1]['Fn::Split'][1].Ref).toEqual("AWS::StackId"); }); - -function IsWholeNumber(target: string): boolean { - const numberPattern = /[0-9]{13}/; - return target.match(numberPattern) !== null; -} diff --git a/source/patterns/@aws-solutions-constructs/core/test/utils.test.ts b/source/patterns/@aws-solutions-constructs/core/test/utils.test.ts index 72de0c7eb..6597b2154 100644 --- a/source/patterns/@aws-solutions-constructs/core/test/utils.test.ts +++ b/source/patterns/@aws-solutions-constructs/core/test/utils.test.ts @@ -64,6 +64,26 @@ test('Test generateResourceName with randomized extension', () => { }); +test('Test generatePhysicalName', () => { + const result = defaults.generatePhysicalName('/aws/vendedlogs/states/constructs/', parts, 255); + + // The token number is not constant, so need to be flexible checking this value + const regex = /\/aws\/vendedlogs\/states\/constructs\/firstportionislongsecondsection-\${Token\[TOKEN\.[0-9]+\]}/; + expect(result).toMatch(regex); +}); + +test('Test truncation of generatePhysicalName', () => { + const longParts = [ ...parts, ...parts, ...parts, ...parts, ...parts ]; + const prefix = '/aws/vendedlogs/states/constructs/'; + const lengthOfGuid = 36; + const maxNameLength = 125; + + const result = defaults.generatePhysicalName(prefix, longParts, maxNameLength); + + const fixedPortion = result.split('$')[0]; + expect(fixedPortion.length).toEqual(maxNameLength - lengthOfGuid); +}); + test('Test generateIntegStackName', () => { const result = defaults.generateIntegStackName('integ.apigateway-dynamodb-CRUD.js'); expect(result).toContain('apigateway-dynamodb-CRUD');