Skip to content

Setting attributes on redfish_bios and redfish_dell_idrac_attributes (possibly others) doesn't show the diff from what is already set #271

Open
@tomelliff

Description

We've started playing with using this provider to configure our fleet of Dell boxes but we've been surprised by how state is being handled here.

We had a few attributes that we wanted to set across our fleet at the BIOS level and for our IPMI but when we first added these resources and ran a plan, the plan showed a full creation of the resources and no diff. We then imported the resources for each of the boxes into state and could see the diffs for what we were setting as well as a bunch of attributes being set to null as a no-op where we hadn't defined them in code.

This seemed fair enough as a one off so we then applied out, saw that the diff was empty after that and then tweaked a single attribute and saw the diff in the plan as expected and didn't show a perpetual diff of undefined attributes being set to null.

However, when we added a new attribute to the resource and ran a plan the diff shows a single attribute being created without showing the diff from what that single attribute is already set to. This means we can't actually tell which boxes are being impacted by this change which is worrying when a BIOS change will immediately trigger a reboot of an unknown amount of boxes. It looks like it's comparing it to the nulls in the state rather than comparing to the refreshed state from the box so it can't show us a useful plan.

We can potentially work around this by removing everything from state and reimporting it all and then setting every single attribute in the Terraform code but this feels unnecessary and in our case will probably lead to a bunch of less important changes having to be applied out, causing reboots in the case of BIOS changes, or us having to make those things variable and defining them at every host configuration that we then for_each over.

It's been a while since I've done any provider work and I haven't looked too deeply into what's happening in this provider but I think the solution should be that the state should contain all of the settings and then you would use a SchemaDiffSuppressFunc to ignore anything that's not set in code from showing as being set to null. Is that something that the maintainers here would be interested in? I don't have a priority for this work but if you're happy for contributions along these lines then if this becomes a priority for my team then I could raise a PR for it if no one else has done it by then.

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions