-
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
feat: add state_key for test run blocks #36185
Conversation
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.
Hi @kevineor, thanks for this. The implementation seems fine to me, just a couple of notes about naming and syntax. The solution here seems simple enough so I'm happy to work through this with you.
I'll just need to check in with our product manager as we have some test work lined up and I want to make sure this doesn't contradict or break anything we have planned, but I don't think there should be any problems.
Also, could you modify the CHANGELOG.md directly in this PR? Thanks!
internal/configs/test_file.go
Outdated
@@ -839,6 +846,7 @@ var testRunOptionsBlockSchema = &hcl.BodySchema{ | |||
{Name: "refresh"}, | |||
{Name: "replace"}, | |||
{Name: "target"}, | |||
{Name: "state_alias"}, |
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.
I wonder if this should be state_key
or even just state
rather than state_alias
. Alias implies it's another name for something rather than what it's doing which is just overriding the default state key.
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.
Ok i'll wait for a definitive decision on your side and i'll apply the change
I agree that it may be confusing. I was also thinking about run_key
as mentioning the state seems weird as is never appears with terraform test
internal/configs/test_file.go
Outdated
@@ -839,6 +846,7 @@ var testRunOptionsBlockSchema = &hcl.BodySchema{ | |||
{Name: "refresh"}, | |||
{Name: "replace"}, | |||
{Name: "target"}, | |||
{Name: "state_alias"}, |
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.
I think I wouldn't put this within the run options block. The run options are a 1:1 mapping to actual run options a user can specify on the command line to the plan command, and overriding the state is not something that can be done this way. I think putting it here confuses things.
I think we can actually just have it at the root level of the run
block. It's metadata about the run block rather than something that changes the behaviour of the plan/apply operation itself.
I've spoken to the product team, and we'd like to hold off on merging this PR for a little while. We're planning on investigating specific controls not just around managing state in memory, but also reading and writing state from the filesystem during tests, and more fine-grained integrations with destroy operations. I think this PR can work in tandem with all of these, but I do want to make sure we don't introduce something that is a one way gate and can't be rolled back without breaking changes. We plan on doing our discovery in Q1 of next year, which means that in terms of releasing this (assuming all goes well with the discovery) there shouldn't be any delay - we'll still aim to merge it as part of the 1.11 release. But we'll include this proposal as part of the general set of discovery work we do, and when we're sure this is compatible with everything else we want to do I'll come back and provide an update. Thanks for your understanding, we do appreciate the contributions but we want to make sure that we're not painting ourselves into a corner with anything. Thanks! |
Okay! Thanks so much for the quick review! I'll go ahead and incorporate your suggestion in the meantime. |
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.
Hi @kevineor - thanks for your patience. I'm happy with the changes in this PR, and I don't think they are going to restrict us going forward.
This is quite a complicated change, and we've switched the way we handle CHANGELOG updates since you raised this PR initially. I've put together #36322 which handles the CHANGELOG entry and docs updates for this change - I just thought that it was easier for me to deal with any feedback we get from the internal docs than it would be for you.
Can you revert your changes to the CHANGELOG and to the tests/index.mdx
file? Once that's done I can approve and merge this for you. Thanks so much for your contribution!
Hello @liamcervante, Thanks a lot for your feedback ! |
While working on terraform module testing, i've been in need for a test case that ensure that a module upgrade is possible. Tests runs can only plan, apply and destroy a complete new infrastructure. My proposal allows to have multiple run blocks that targets the same infrastructure.
This could allow to make module upgrade tests, by ensuring the second apply using the new code still pass, or even checking that ressources does not get recreated.
Example code i want to implement :
Fixes #35080
PR Modifications ideas
I'm not sure about naming and where this option should be added
state_alias
tostate_key
?state_alias
fromplan_options
torun
block ?Target Release
1.11.x
Draft CHANGELOG entry
NEW FEATURES | UPGRADE NOTES | ENHANCEMENTS | BUG FIXES | EXPERIMENTS
terraform test
command now supports astate_alias
attribute inplan_option
blocks during test runs. This feature allows multiple Terraform test runs to target the same infrastructure.