Skip to content
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

Component option propagation (NodeJS SDK) #2713

Merged
merged 3 commits into from
Jan 3, 2024

Conversation

EronWright
Copy link
Contributor

@EronWright EronWright commented Dec 13, 2023

Proposed changes

Epic: #2254
Fixes: #1938
Fixes: #2049
Fixes: #812

This PR standardizes the option propagation logic for the component resources in the pulumi-kubernetes NodeJS SDK. The general approach is:

  1. In the component resource constructor, compute the child options to be propagated to any children. The child options consist of the component as parent, and with version and pluginDownloadURL if specified.
  2. Compute the invoke options by copying the child options.

Specification

The component resource is responsible for computing sub-options for invokes and for child resource declarations. This table outlines the expected behavior for each resource option when presented to a component resource.

Propagated Remarks
additionalSecretOutputs no "does not apply to component resources"
aliases no Inherited via parent-child relationship.
customTimeouts no "does not apply to component resources"
deleteBeforeReplace no
deletedWith no
dependsOn no The children implicitly wait for the dependency.
ignoreChanges no Nonsensical to apply directly to children (see discussion).
import no
parent yes The component becomes the parent.
protect no Inherited.
provider no Combined into providers map, then inherited via parent-child relationship.
providers no Inherited.
replaceOnChanges no "does not apply to component resources"
retainOnDelete no "does not apply to component resources"
transformations no Inherited.
version yes Influences default provider selection logic during invokes.
Should propagate when child resource is from the same provider type.
pluginDownloadURL yes Influences default provider selection logic during invokes.
Should propagate when child resource is from the same provider type.

Testing

A new test case is provided (test case, test program) that exercises option propagation across the component resources:

Upgrade testing must be done manually, with an emphasis on avoiding replacement due to reparenting.

Related issues (optional)

The p/p NodeJS SDK doesn't propagate the pluginDownloadURL option to the Invoke RPC.
pulumi/pulumi#14839

Copy link

Does the PR have any schema changes?

Looking good! No breaking changes found.
No new resources/functions.

@EronWright EronWright force-pushed the eronwright/issue-2254-nodejs branch from e1ad541 to 0630cee Compare January 3, 2024 22:55
@EronWright EronWright merged commit afe1f1b into master Jan 3, 2024
18 checks passed
@EronWright EronWright deleted the eronwright/issue-2254-nodejs branch January 3, 2024 23:51
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
2 participants