Skip to content

knownvalue: Consider Pointer-Based Checks #302

Open
@bflad

Description

@bflad

terraform-plugin-testing version

v1.7.0

Use cases

The v1.7.0 release introduced the experimental knownvalue package for writing value-specific assertions against known resource attribute and output values. This initially exposed checks such as:

  • Bool(value bool)
  • Float64Exact(value float64)
  • Int64Exact(value int64)
  • StringExact(value string)

The values for these checks may not be known upfront with a developer hardcoding the value. For example in #295, computed attribute values are compared to an API response type where the struct fields are pointers. Attempting to declaratively dereference the field value pointer to use the existing known value checks would almost undoubtedly cause a panic when running the test since the dereferencing operation would occur during compilation while its still nil.

Proposal

Caveat: This proposal only suggests asserting values that are already pointers to Go built-in types, not potentially extracting values into the pointer. That proposal should be submitted separately and has many more considerations of whether it should be offered natively or what form it should take.

Verify whether this testing pattern is prevalent in the ecosystem or might become prevalent with the newer checks. If not, do nothing.

Introduce the following into the knownvalue package:

  • BoolPointer(value *bool)
  • Float64PointerExact(value *float64)
  • Int64PointerExact(value *int64)
  • StringPointerExact(value *string)

If the given value argument is nil, return an error that alludes to using the Null check instead. This would be intended to prevent developers from testing implementation errors and from relying on these checks for null checking.

Otherwise, the check logic can dereference the pointer and perform an exact equality check.

References

Metadata

Metadata

Assignees

No one assigned

    Labels

    enhancementNew feature or request

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions