mirror of https://github.com/pulumi/pulumi.git
49d8298e84
This fixes a snapshot integrity issue with delete before replace, failed creates, and multiple updates. This was caused by https://github.com/pulumi/pulumi/pull/16510 where we started removing pending replace resources as part of their replacement steps. A well intentioned fix to stop trying to delete resources we'd already deleted in a previous update. The bug would manifest if the following happened: 1. An update goes to replace a resource with `deleteBeforeCreate` set. It deletes the old resource (and saves the state as pending replace) but then failed to create the new replacement resource. 2. A second update is run to try and create the replacement resource. At this point the bug manifest and we delete the pending replace resource from state, but then if the new resource fails to create again we end up with an invalid snapshot. The fix is very simple. If a resource is already pending replacement we just don't issue a delete/remove step at all. The pending replace resource will get cleaned up at the end by the create step creating the new version. Fixes #17111 Fixes #17073 Fixes #17070 Fixes #17069 Fixes #16916 |
||
---|---|---|
.. | ||
testdata | ||
alias_test.go | ||
analyzer_test.go | ||
continue_on_error_test.go | ||
delete_before_replace_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 | ||
test_plan.go | ||
transformation_test.go | ||
update_plan_test.go |