From 29cc42e41c3bb07476fd9f2ea8ea81cfb6c334bb Mon Sep 17 00:00:00 2001 From: Rohit Aggarwal Date: Mon, 28 Nov 2022 11:42:32 -0800 Subject: [PATCH] fix(servicecatalogappregistry): creating ApplicationStack in AppScope to give user more control over the passed stackId (#22977) As a user, I want to have full control over the stack ID, to maintain a naming convention when using AWS CDK Toolkit. AWS CDK Construct Library v2.51.0 allows to set the stack ID for TargetApplication, but prefixes the name with the containing construct ID. Fixes #22973 BREAKING CHANGE: Stack inside ApplicationAssociator is no longer is created inside ApplicationAssociator Construct scope. The stack will now get created inside cdk.App scope. * ** servicecatalogappregistry:** stackId will no longer have ApplicationAssociator Construct scope. ### All Submissions: * [ X] Have you followed the guidelines in our [Contributing guide?](https://github.com/aws/aws-cdk/blob/main/CONTRIBUTING.md) ### Adding new Unconventional Dependencies: * [ ] This PR adds new unconventional dependencies following the process described [here](https://github.com/aws/aws-cdk/blob/main/CONTRIBUTING.md/#adding-new-unconventional-dependencies) ### New Features * [ ] Have you added the new feature to an [integration test](https://github.com/aws/aws-cdk/blob/main/INTEGRATION_TESTS.md)? * [ ] Did you use `yarn integ` to deploy the infrastructure and generate the snapshot (i.e. `yarn integ` without `--dry-run`)? *By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license* --- .../lib/application-associator.ts | 2 +- .../lib/target-application.ts | 3 +- ...> AppRegistryApplicationStack.assets.json} | 6 +- ...AppRegistryApplicationStack.template.json} | 3 +- .../integ.json | 14 ---- .../manifest.json | 42 +++++----- .../tree.json | 78 +++++++++++++++---- ...ation-associator.all-stacks-association.ts | 1 + 8 files changed, 93 insertions(+), 56 deletions(-) rename packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/{ApplicationAssociatorStack.assets.json => AppRegistryApplicationStack.assets.json} (65%) rename packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/{ApplicationAssociatorStack.template.json => AppRegistryApplicationStack.template.json} (89%) delete mode 100644 packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/integ.json diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/lib/application-associator.ts b/packages/@aws-cdk/aws-servicecatalogappregistry/lib/application-associator.ts index 2d6fafdac34e8..1cd296d9f074a 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/lib/application-associator.ts +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/lib/application-associator.ts @@ -42,7 +42,7 @@ export class ApplicationAssociator extends Construct { } const targetApplication = props.applications[0]; - this.application = targetApplication.bind(this).application; + this.application = targetApplication.bind(scope).application; cdk.Aspects.of(scope).add(new CheckedStageStackAssociator(this)); } diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/lib/target-application.ts b/packages/@aws-cdk/aws-servicecatalogappregistry/lib/target-application.ts index f3684b4783554..7745c0d99a02c 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/lib/target-application.ts +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/lib/target-application.ts @@ -7,7 +7,8 @@ import { IApplication, Application } from './application'; */ export interface TargetApplicationCommonOptions extends cdk.StackProps { /** - * Stack ID in which application will be created or imported. + * Stack ID in which application will be created or imported. The id of a stack is also the identifier that you use to + * refer to it in the {@link https://docs.aws.amazon.com/cdk/v2/guide/cli.html | AWS CDK Toolkit (cdk command)}. * * @default - ApplicationAssociatorStack */ diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/ApplicationAssociatorStack.assets.json b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/AppRegistryApplicationStack.assets.json similarity index 65% rename from packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/ApplicationAssociatorStack.assets.json rename to packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/AppRegistryApplicationStack.assets.json index 2f99ef79e2174..9b7245da02eeb 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/ApplicationAssociatorStack.assets.json +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/AppRegistryApplicationStack.assets.json @@ -1,15 +1,15 @@ { "version": "21.0.0", "files": { - "4285054f947789e255e76c75b889b3b216adabb0b3f990c8966c18459cdf7b35": { + "096a2ebc1093f405e713a82ffa6755ace9d5244a06f746653f025546795d3a0a": { "source": { - "path": "ApplicationAssociatorStack.template.json", + "path": "AppRegistryApplicationStack.template.json", "packaging": "file" }, "destinations": { "current_account-current_region": { "bucketName": "cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}", - "objectKey": "4285054f947789e255e76c75b889b3b216adabb0b3f990c8966c18459cdf7b35.json", + "objectKey": "096a2ebc1093f405e713a82ffa6755ace9d5244a06f746653f025546795d3a0a.json", "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-file-publishing-role-${AWS::AccountId}-${AWS::Region}" } } diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/ApplicationAssociatorStack.template.json b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/AppRegistryApplicationStack.template.json similarity index 89% rename from packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/ApplicationAssociatorStack.template.json rename to packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/AppRegistryApplicationStack.template.json index 79c9dec209b9e..ad3a17394aff1 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/ApplicationAssociatorStack.template.json +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/AppRegistryApplicationStack.template.json @@ -1,10 +1,11 @@ { + "Description": "Stack that holds the AppRegistryAssociatedApplication application", "Resources": { "DefaultCdkApplication4573D5A3": { "Type": "AWS::ServiceCatalogAppRegistry::Application", "Properties": { "Name": "AppRegistryAssociatedApplication", - "Description": "Testing AppRegistry ApplicationAssociator" + "Description": "Application containing stacks deployed via CDK." } }, "AppRegistryAssociation": { diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/integ.json b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/integ.json deleted file mode 100644 index 1f1a144803dcd..0000000000000 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/integ.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "version": "21.0.0", - "testCases": { - "integ.application-associator.all-stacks-association": { - "stacks": [ - "integ-servicecatalogappregistry-application" - ], - "diffAssets": false, - "stackUpdateWorkflow": true - } - }, - "synthContext": {}, - "enableLookups": false -} \ No newline at end of file diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/manifest.json b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/manifest.json index 65db06b047d68..1bc99b491fee1 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/manifest.json +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/manifest.json @@ -1,12 +1,6 @@ { "version": "21.0.0", "artifacts": { - "Tree": { - "type": "cdk:tree", - "properties": { - "file": "tree.json" - } - }, "integservicecatalogappregistryapplicationresourcesStack4399A149.assets": { "type": "cdk:asset-manifest", "properties": { @@ -36,7 +30,7 @@ } }, "dependencies": [ - "ApplicationAssociatorStack", + "AppRegistryApplicationStack", "integservicecatalogappregistryapplicationresourcesStack4399A149.assets" ], "metadata": { @@ -100,7 +94,7 @@ } }, "dependencies": [ - "ApplicationAssociatorStack", + "AppRegistryApplicationStack", "integ-servicecatalogappregistry-application.assets" ], "metadata": { @@ -135,27 +129,27 @@ }, "displayName": "integ-servicecatalogappregistry-application" }, - "ApplicationAssociatorStack.assets": { + "AppRegistryApplicationStack.assets": { "type": "cdk:asset-manifest", "properties": { - "file": "ApplicationAssociatorStack.assets.json", + "file": "AppRegistryApplicationStack.assets.json", "requiresBootstrapStackVersion": 6, "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version" } }, - "ApplicationAssociatorStack": { + "AppRegistryApplicationStack": { "type": "aws:cloudformation:stack", "environment": "aws://unknown-account/unknown-region", "properties": { - "templateFile": "ApplicationAssociatorStack.template.json", + "templateFile": "AppRegistryApplicationStack.template.json", "validateOnSynth": false, "assumeRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-deploy-role-${AWS::AccountId}-${AWS::Region}", "cloudFormationExecutionRoleArn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-cfn-exec-role-${AWS::AccountId}-${AWS::Region}", - "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/4285054f947789e255e76c75b889b3b216adabb0b3f990c8966c18459cdf7b35.json", + "stackTemplateAssetObjectUrl": "s3://cdk-hnb659fds-assets-${AWS::AccountId}-${AWS::Region}/096a2ebc1093f405e713a82ffa6755ace9d5244a06f746653f025546795d3a0a.json", "requiresBootstrapStackVersion": 6, "bootstrapStackVersionSsmParameter": "/cdk-bootstrap/hnb659fds/version", "additionalDependencies": [ - "ApplicationAssociatorStack.assets" + "AppRegistryApplicationStack.assets" ], "lookupRole": { "arn": "arn:${AWS::Partition}:iam::${AWS::AccountId}:role/cdk-hnb659fds-lookup-role-${AWS::AccountId}-${AWS::Region}", @@ -165,10 +159,10 @@ "stackName": "AppRegistryApplicationAssociatorStack" }, "dependencies": [ - "ApplicationAssociatorStack.assets" + "AppRegistryApplicationStack.assets" ], "metadata": { - "/ApplicationAssociatorStack": [ + "/AppRegistryApplicationStack": [ { "type": "aws:cdk:warning", "data": "Environment agnostic stack determined, AppRegistry association might not work as expected in case you deploy cross-region or cross-account stack." @@ -178,32 +172,38 @@ "data": "Environment agnostic stack determined, AppRegistry association might not work as expected in case you deploy cross-region or cross-account stack." } ], - "/ApplicationAssociatorStack/DefaultCdkApplication/Resource": [ + "/AppRegistryApplicationStack/DefaultCdkApplication/Resource": [ { "type": "aws:cdk:logicalId", "data": "DefaultCdkApplication4573D5A3" } ], - "/ApplicationAssociatorStack/AppRegistryAssociation": [ + "/AppRegistryApplicationStack/AppRegistryAssociation": [ { "type": "aws:cdk:logicalId", "data": "AppRegistryAssociation" } ], - "/ApplicationAssociatorStack/BootstrapVersion": [ + "/AppRegistryApplicationStack/BootstrapVersion": [ { "type": "aws:cdk:logicalId", "data": "BootstrapVersion" } ], - "/ApplicationAssociatorStack/CheckBootstrapVersion": [ + "/AppRegistryApplicationStack/CheckBootstrapVersion": [ { "type": "aws:cdk:logicalId", "data": "CheckBootstrapVersion" } ] }, - "displayName": "ApplicationAssociatorStack" + "displayName": "AppRegistryApplicationStack" + }, + "Tree": { + "type": "cdk:tree", + "properties": { + "file": "tree.json" + } } } } \ No newline at end of file diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/tree.json b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/tree.json index 078cc92093b86..49927b71d408b 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/tree.json +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.js.snapshot/tree.json @@ -4,14 +4,6 @@ "id": "App", "path": "", "children": { - "Tree": { - "id": "Tree", - "path": "Tree", - "constructInfo": { - "fqn": "constructs.Construct", - "version": "10.1.95" - } - }, "integ-servicecatalogappregistry-application": { "id": "integ-servicecatalogappregistry-application", "path": "integ-servicecatalogappregistry-application", @@ -37,6 +29,22 @@ "fqn": "@aws-cdk/aws-servicecatalogappregistry.CfnResourceAssociation", "version": "0.0.0" } + }, + "BootstrapVersion": { + "id": "BootstrapVersion", + "path": "integ-servicecatalogappregistry-application/resourcesStack/BootstrapVersion", + "constructInfo": { + "fqn": "@aws-cdk/core.CfnParameter", + "version": "0.0.0" + } + }, + "CheckBootstrapVersion": { + "id": "CheckBootstrapVersion", + "path": "integ-servicecatalogappregistry-application/resourcesStack/CheckBootstrapVersion", + "constructInfo": { + "fqn": "@aws-cdk/core.CfnRule", + "version": "0.0.0" + } } }, "constructInfo": { @@ -61,6 +69,22 @@ "fqn": "@aws-cdk/aws-servicecatalogappregistry.CfnResourceAssociation", "version": "0.0.0" } + }, + "BootstrapVersion": { + "id": "BootstrapVersion", + "path": "integ-servicecatalogappregistry-application/BootstrapVersion", + "constructInfo": { + "fqn": "@aws-cdk/core.CfnParameter", + "version": "0.0.0" + } + }, + "CheckBootstrapVersion": { + "id": "CheckBootstrapVersion", + "path": "integ-servicecatalogappregistry-application/CheckBootstrapVersion", + "constructInfo": { + "fqn": "@aws-cdk/core.CfnRule", + "version": "0.0.0" + } } }, "constructInfo": { @@ -76,22 +100,22 @@ "version": "0.0.0" } }, - "ApplicationAssociatorStack": { - "id": "ApplicationAssociatorStack", - "path": "ApplicationAssociatorStack", + "AppRegistryApplicationStack": { + "id": "AppRegistryApplicationStack", + "path": "AppRegistryApplicationStack", "children": { "DefaultCdkApplication": { "id": "DefaultCdkApplication", - "path": "ApplicationAssociatorStack/DefaultCdkApplication", + "path": "AppRegistryApplicationStack/DefaultCdkApplication", "children": { "Resource": { "id": "Resource", - "path": "ApplicationAssociatorStack/DefaultCdkApplication/Resource", + "path": "AppRegistryApplicationStack/DefaultCdkApplication/Resource", "attributes": { "aws:cdk:cloudformation:type": "AWS::ServiceCatalogAppRegistry::Application", "aws:cdk:cloudformation:props": { "name": "AppRegistryAssociatedApplication", - "description": "Testing AppRegistry ApplicationAssociator" + "description": "Application containing stacks deployed via CDK." } }, "constructInfo": { @@ -107,7 +131,7 @@ }, "AppRegistryAssociation": { "id": "AppRegistryAssociation", - "path": "ApplicationAssociatorStack/AppRegistryAssociation", + "path": "AppRegistryApplicationStack/AppRegistryAssociation", "attributes": { "aws:cdk:cloudformation:type": "AWS::ServiceCatalogAppRegistry::ResourceAssociation", "aws:cdk:cloudformation:props": { @@ -127,12 +151,36 @@ "fqn": "@aws-cdk/aws-servicecatalogappregistry.CfnResourceAssociation", "version": "0.0.0" } + }, + "BootstrapVersion": { + "id": "BootstrapVersion", + "path": "AppRegistryApplicationStack/BootstrapVersion", + "constructInfo": { + "fqn": "@aws-cdk/core.CfnParameter", + "version": "0.0.0" + } + }, + "CheckBootstrapVersion": { + "id": "CheckBootstrapVersion", + "path": "AppRegistryApplicationStack/CheckBootstrapVersion", + "constructInfo": { + "fqn": "@aws-cdk/core.CfnRule", + "version": "0.0.0" + } } }, "constructInfo": { "fqn": "@aws-cdk/core.Stack", "version": "0.0.0" } + }, + "Tree": { + "id": "Tree", + "path": "Tree", + "constructInfo": { + "fqn": "constructs.Construct", + "version": "10.1.161" + } } }, "constructInfo": { diff --git a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.ts b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.ts index d3849f5aed251..c6c70bcfac07b 100644 --- a/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.ts +++ b/packages/@aws-cdk/aws-servicecatalogappregistry/test/integ.application-associator.all-stacks-association.ts @@ -10,6 +10,7 @@ new appreg.ApplicationAssociator(app, 'RegisterCdkApplication', { applications: [appreg.TargetApplication.createApplicationStack({ applicationName: 'AppRegistryAssociatedApplication', stackName: 'AppRegistryApplicationAssociatorStack', + stackId: 'AppRegistryApplicationStack', })], });