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

Avoid panics when testing nested sets of varying depth #648

Merged
merged 1 commit into from
Jan 4, 2021

Conversation

IronSavior
Copy link
Contributor

@IronSavior IronSavior commented Nov 27, 2020

I encountered a panic when I have a hierarchical attribute where the depth of the hierarchy isn't necessarily the same for all objects. The panic is caused by an out of bounds slice index in cases where you specify an attribute path greater than or equal to the deepest structure in state when using TestCheckTypeSetElemNestedAttrs().

example - Let's say there are groups that can have sub-groups. Your state contains 4 groups and three of them are in a chain and the other has no sub-groups:

group1 <- group 2 <- group3

group4

When a unit test tries to match TestCheckTypeSetElemNestedAttrs("groups.*.groups.*.groups.*", map[string]string{"name": expectedName}), it will panic because groups.*.groups.*.groups.* causes the check to index too far into group4.

@hashicorp-cla
Copy link

hashicorp-cla commented Nov 27, 2020

CLA assistant check
All committers have signed the CLA.

@paddycarver paddycarver added the subsystem/tests Issues and feature requests related to the testing framework. label Dec 17, 2020
Copy link
Contributor

@paddycarver paddycarver left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think I'm following, and this seems reasonable enough to me. Thanks!

@paddycarver paddycarver merged commit daf1427 into hashicorp:master Jan 4, 2021
@ghost
Copy link

ghost commented Feb 4, 2021

I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues.

If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further.

@ghost ghost locked as resolved and limited conversation to collaborators Feb 4, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
subsystem/tests Issues and feature requests related to the testing framework.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants