mirror of https://github.com/pulumi/pulumi.git
1da0555b6a
*Components* provide a means for Pulumi users to logically group and abstract sets of resources. While authors of Pulumi programs can define "local" components using e.g. the `ComponentResource` class of the NodeJS or Python SDK, these can only be consumed by programs written in the same language. Components implemented by provider `Construct` implementations, however (often called "remote" components), can be consumed by any appropriate client SDK, just like any other Pulumi resource. Despite their implementation involving gRPC protocol communications, remote components offer many of the same features as local components. For instance, just as it is possible for a local component's outputs to contain references to its child resources, so may a remote component return references to resources instantiated in its `Construct` implementation. On the wire, these are serialized using resource URNs and IDs. These values are then "hydrated" into fully fledged resource values by the calling client SDK. Hydration is powered by the `pulumi:pulumi:getResource` function. This is an invoke offered by the so-called *built-in* provider, alongside other core Pulumi concerns such as stack references. Under the hood, `getResource` is implemented by looking up URNs in a table of resources being managed by the executing program, and returning the appropriate state to the caller. Presently, this lookup only takes into account resources managed by Pulumi (that is, *resource registrations*). It does not take into account *reads* such as those caused by e.g. a `.get` call in a NodeJS SDK. Consequently, if a `Construct` implementation performs a `.get` and returns a reference to the read resource as an output, later hydrations of that reference will fail. This is the cause of #17515. This change fixes this by augmenting the built-in provider with a map of read resources, which is updated as a deployment progresses just as the list of registered resources being used already is. When a lookup in the registrations map fails, the read map is tried, with an error being raised only if that also fails. A pair of lifecycle tests are added to verify that the behaviour works as intended. Fixes #17515 |
||
---|---|---|
.. | ||
framework | ||
fuzzing | ||
testdata | ||
README.md | ||
alias_test.go | ||
analyzer_test.go | ||
autonaming_test.go | ||
components_test.go | ||
continue_on_error_test.go | ||
delete_before_replace_test.go | ||
fuzz_test.go | ||
golang_sdk_test.go | ||
import_test.go | ||
loader_test.go | ||
parameterized_test.go | ||
pending_delete_test.go | ||
pending_replace_test.go | ||
provider_test.go | ||
pulumi_test.go | ||
refresh_legacy_diff_test.go | ||
refresh_test.go | ||
resource_reference_test.go | ||
retain_on_delete_test.go | ||
source_query_test.go | ||
step_generator_test.go | ||
target_test.go | ||
transformation_test.go | ||
update_plan_test.go |
README.md
(lifecycle-tests)=
Lifecycle tests
Lifecycle tests exercise the Pulumi engine and serve as a specification for the behaviours and interactions of the various features that define the lifecycle of a Pulumi program. This includes, but is not limited to:
- The operation(s) being executed (
up
,preview
, etc.) and the options passed to that operation (--target
,--target-dependents
, etc.). - The programs being executed -- their resources, invocations, and the various
options that might be associated with them (
parent
,retainOnDelete
, etc.). - The state of the program before and after operations are executed.
How and when to use