-
Notifications
You must be signed in to change notification settings - Fork 4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(servicecatalogappregistry): Associate an application with attribute group #24378
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for your contribution, we cannot provide a meaningful review until there is a passing build. If you have questions about the build failure, please let us know.
Please make sure that your PR title confirms to the conventional commit standard (fix, feat, chore) and that it is written in a style that will reflect correctly in the change log (See Contributing Guide, Pull Requests). Specifically, a fix should state the bug, not the solution.
Lastly, is there an open issue for this? If so, please link it in the PR body.
Pull request has been modified.
Thanks for getting the build passing. The last two pieces of my comment will still need to be addressed.
|
PR title confirms to the conventional commit standard. This PR is for a bug fix in |
class CustomAppRegistryAttributeGroup extends cdk.Stack { | ||
public readonly attributeGroup: appreg.AttributeGroup | ||
constructor(scope: Construct, id: string, props?: cdk.StackProps) { | ||
super(scope, id, props); | ||
const myAttributeGroup = new appreg.AttributeGroup(app, 'MyFirstAttributeGroup', { | ||
attributeGroupName: 'MyAttributeGroupName', | ||
description: 'Test attribute group', | ||
attributes: {}, | ||
}); | ||
|
||
this.attributeGroup = myAttributeGroup; | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Do we really expect people to define a stack for their AttributeGroup? Couldn't it go into one of the other stacks?
For example, wouldn't it make sense for a user to do:
const associatedApp = new appreg.ApplicationAssociator(app, 'AssociatedApplication', {
applications: [ /* ... */],
attributes: {
// ...
},
});
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
attributes
is not a valid input as per ApplicationAssociatorProps. Attribute group can definitely be a part of some other stack, however customers need to explicitly associate the attribute group to the application, as ApplicationAssociator
is responsible to associate the stacks within the scope, it wont automatically associate the underlying AGs within a stack.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
attributes is not a valid input as per ApplicationAssociatorProps
I understand.
The nice thing about software is that it is not like the laws of physics. It is in fact changeable.
- FACT: "attributes" can not be passed to the ApplicationAssociator
- QUESTION: would it be better/easier/more convenient/more obvious IF "attributes" could be passed to ApplicationAssociator, and the creation of the AttributeGroup happens implicitly?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
TBH I like this idea of including attribute-group
in application-associator
construct. However, can we first prioritize this bug fix which will unblock our customers and they should be able to associate an attribute group to an application.
I will do some more deep dive on including attribute-group
in application-associator
, its pros and cons and will let you know about our plan to modify application-associator
in order to include attribute-group
.
Let me know if this plan works for you.
declare const application: appreg.Application; | ||
declare const attributeGroup: appreg.AttributeGroup; | ||
attributeGroup.associateApplicationWithAttributeGroup(application); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is good, although the method name is a little long. Given that the subject is of type AttributeGroup
and the object is of type Application
, do you really think we need the words "Application" and "AttributeGroup" in the method name?
Why not
attributeGroup.associate(application);
// or
attributeGroup.associateWith(application);
// or
attributeGroup.associateTo(application);
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yeah associateWith
makes a lot more sense. Changed the same in the latest version.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
See my previous comment: do we want to force the user to create an attributegroup themselves?
I think users would prefer to minimize the amount of stacks in their account if possible.
Thank you for contributing! Your pull request will be updated from main and then merged automatically (do not update manually, and be sure to allow changes to be pushed to your fork). |
AWS CodeBuild CI Report
Powered by github-codebuild-logs, available on the AWS Serverless Application Repository |
Thank you for contributing! Your pull request will be updated from main and then merged automatically (do not update manually, and be sure to allow changes to be pushed to your fork). |
…te group (aws#24378) `Application-AttributeGroup` association happens in `ApplicationStack`. Therefore before the deployment of `ApplicationStack`, `AttributeGroup` stack should have been deployed. But with `ApplicationAssociator `where we associate all the stacks with the application (created as a part of `ApplicationAssociator`), attributeGroup stack now depends upon `ApplicationAssociator` stack to be created (since ResourceAssociation happens inside ResourceStack). This creates a circular dependency and hence cdk synth fails. We found this bug during internal testing This PR address this circular dependency issue, by allowing the customers of `ApplicationAssociator` to associate an attribute group in attribute group stack. ---- *By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license*
Application-AttributeGroup
association happens inApplicationStack
.Therefore before the deployment of
ApplicationStack
,AttributeGroup
stack should have been deployed.But with
ApplicationAssociator
where we associate all the stacks with the application (created as a part ofApplicationAssociator
), attributeGroup stack now depends uponApplicationAssociator
stack to be created (since ResourceAssociation happens inside ResourceStack).This creates a circular dependency and hence cdk synth fails. We found this bug during internal testing
This PR address this circular dependency issue, by allowing the customers of
ApplicationAssociator
to associate an attribute group in attribute group stack.By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license