-
Notifications
You must be signed in to change notification settings - Fork 9.6k
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 destroy-time handling of outputs and local values #17241
Merged
Merged
Changes from 8 commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
7da1a39
always evaluate locals, even during destroy
jbardin 7ac0a46
add destroy provisioner test with locals, outputs
jbardin 0813955
always evaluate outputs too
jbardin d31fe5a
delete outputs during destroy
jbardin 2d138d9
add a more complex locals test
jbardin 99867f0
add PruneUnusedValuesTransformer
jbardin a2f8482
catch missing id attribute during interpolation
jbardin ca4178b
gofmt bug will be fixed in 1.10
jbardin 7fbc35a
Make sure outputs are removed when targeting
jbardin File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -59,38 +59,8 @@ func (n *NodeLocal) References() []string { | |
|
||
// GraphNodeEvalable | ||
func (n *NodeLocal) EvalTree() EvalNode { | ||
return &EvalSequence{ | ||
Nodes: []EvalNode{ | ||
&EvalOpFilter{ | ||
Ops: []walkOperation{ | ||
walkInput, | ||
walkValidate, | ||
walkRefresh, | ||
walkPlan, | ||
walkApply, | ||
}, | ||
Node: &EvalSequence{ | ||
Nodes: []EvalNode{ | ||
&EvalLocal{ | ||
Name: n.Config.Name, | ||
Value: n.Config.RawConfig, | ||
}, | ||
}, | ||
}, | ||
}, | ||
&EvalOpFilter{ | ||
Ops: []walkOperation{ | ||
walkPlanDestroy, | ||
walkDestroy, | ||
}, | ||
Node: &EvalSequence{ | ||
Nodes: []EvalNode{ | ||
&EvalDeleteLocal{ | ||
Name: n.Config.Name, | ||
}, | ||
}, | ||
}, | ||
}, | ||
}, | ||
return &EvalLocal{ | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This is much nicer! |
||
Name: n.Config.Name, | ||
Value: n.Config.RawConfig, | ||
} | ||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
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.
Is this something that can really happen in practice, or was this more just a result of us tending to be lazy about fully-constructing state in tests?
Not objecting to doing it to be safe in the mean time, but just curious as to what tripped this up and prompted you to add the branch here.
(The new provider protocols and state format no longer have this special
ID
field, as you know, so an end to this odd special-case is not too far in the future but of course we'll need to watch out during that change for situations like this were we're doing something special to keep the two aligned.)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, it's a destroy-time issue, and we do run into it quite often. I'm actually not sure what order of operations through helper/schema get us in this situation, but as you said it is hopefully going away so this would only be temporary. I added the check now because the extra local/output evaluations during destroy are much more likely to encounter the situation.