Skip to content

fix(ec2): UserData.addSignalOnExitCommand does not work in combination with userDataCausesReplacement#18726

Merged
mergify[bot] merged 2 commits intoaws:masterfrom
corymhall:corymhall/fix-ec2-cfn-signal
Jan 31, 2022
Merged

fix(ec2): UserData.addSignalOnExitCommand does not work in combination with userDataCausesReplacement#18726
mergify[bot] merged 2 commits intoaws:masterfrom
corymhall:corymhall/fix-ec2-cfn-signal

Conversation

@corymhall
Copy link
Copy Markdown
Contributor

If both addSignalOnExitCommand and userDataCausesReplacement are
used it results in an invalid logicalId being used in the
cfn-signal call. This is due to addSignalOnExitCommand getting the
logicalID from Stack.getLogicalId which does not take into
consideration logicalId overrides which userDataCausesReplacement
uses.

This updates addSignalOnExitCommand to use the logicalId of the
resource which is evaluated lazily and happens after all overrides.

fixes #12749


By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license

…alID

If both `addSignalOnExitCommand` _and_ `userDataCausesReplacement` are
both used it results in an invalid logicalId being used in the
`cfn-signal` call. This is due to `addSignalOnExitCommand` getting the
logicalID from `Stack.getLogicalId` which does not take into
consideration logicalId overrides which `userDataCausesReplacement`
uses.

This updates `addSignalOnExitCommand` to use the `logicalId` of the
resource.

fixes #12749
@gitpod-io
Copy link
Copy Markdown

gitpod-io bot commented Jan 28, 2022

@mergify mergify bot added the contribution/core This is a PR that came from AWS. label Jan 28, 2022
@corymhall corymhall requested a review from a team January 28, 2022 18:26
@rix0rrr rix0rrr changed the title fix(ec2): UserData.addSignalOnExitCommand uses invalid resource logicalID fix(ec2): UserData.addSignalOnExitCommand does not work in combination with userDataCausesReplacement Jan 31, 2022
@mergify
Copy link
Copy Markdown
Contributor

mergify bot commented Jan 31, 2022

Thank you for contributing! Your pull request will be updated from master and then merged automatically (do not update manually, and be sure to allow changes to be pushed to your fork).

@aws-cdk-automation
Copy link
Copy Markdown
Collaborator

AWS CodeBuild CI Report

  • CodeBuild project: AutoBuildProject89A8053A-LhjRyN9kxr8o
  • Commit ID: 2a1b691
  • Result: SUCCEEDED
  • Build Logs (available for 30 days)

Powered by github-codebuild-logs, available on the AWS Serverless Application Repository

@mergify mergify bot merged commit afdc550 into aws:master Jan 31, 2022
@mergify
Copy link
Copy Markdown
Contributor

mergify bot commented Jan 31, 2022

Thank you for contributing! Your pull request will be updated from master and then merged automatically (do not update manually, and be sure to allow changes to be pushed to your fork).

kornicameister added a commit to kornicameister/aws-cdk that referenced this pull request Feb 3, 2022
* origin/master: (74 commits)
  chore: remove reliance on `decdk` in build system (aws#18760)
  chore: add repository directory for all packages.json  (aws#17203)
  docs(ecs): correct comment documentation for NetworkMode (aws#17841)
  feat(ecs): expose image name in container definition (aws#17793)
  feat(ecr): add server-side encryption configuration  (aws#16966)
  chore(region-info): ap-southeast-3 (Jakarta) ROUTE_53_BUCKET_WEBSITE_ZONE_ID (aws#18110)
  chore: reassign njlynch's ownership areas (aws#18751)
  chore(ecs-service-extensions): migrate tests to assertions (aws#18649)
  chore(s3): Fixed documentation for `InventoryFormat.ORC` (aws#18717)
  feat(iot): add Action to republish MQTT messages to another MQTT topic (aws#18661)
  chore(rds): add support for PostgreSQL 14 (aws#18713)
  fix(core): correctly reference versionless secure parameters (aws#18730)
  fix(ec2): `UserData.addSignalOnExitCommand` does not work in combination with `userDataCausesReplacement` (aws#18726)
  fix(vpc): Vpc.fromLookup should throw if subnet group name tag is explicitly given and does not exist (aws#18714)
  docs(dynamodb): add note around table encryption (aws#18721)
  chore: override `markdown-it` version (aws#18723)
  docs(cfnspec): update CloudFormation documentation (aws#18741)
  chore(release): 1.142.0
  chore(lambda-layer-awscli): contains a CLI version with a CVE (aws#18727)
  chore(lambda-python): remove Pillow dependency (aws#18722)
  ...
TikiTDO pushed a commit to TikiTDO/aws-cdk that referenced this pull request Feb 21, 2022
…ion with `userDataCausesReplacement` (aws#18726)

If both `addSignalOnExitCommand` _and_ `userDataCausesReplacement` are
 used it results in an invalid logicalId being used in the
`cfn-signal` call. This is due to `addSignalOnExitCommand` getting the
logicalID from `Stack.getLogicalId` which does not take into
consideration logicalId overrides which `userDataCausesReplacement`
uses.

This updates `addSignalOnExitCommand` to use the `logicalId` of the
resource which is evaluated lazily and happens after all overrides.

fixes aws#12749


----

*By submitting this pull request, I confirm that my contribution is made under the terms of the Apache-2.0 license*
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

contribution/core This is a PR that came from AWS.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

(aws-ec2): userDataCausesReplacement timeouts, if resourceSignalTimeout is set

3 participants