mirror of
https://github.com/opentofu/opentofu.git
synced 2024-12-27 09:21:14 -06:00
Merge pull request #27238 from hashicorp/pselle/count-sensitive
Unmark values in count before go conversion
This commit is contained in:
commit
6e1017f247
@ -60,6 +60,10 @@ func evaluateCountExpressionValue(expr hcl.Expression, ctx EvalContext) (cty.Val
|
|||||||
return nullCount, diags
|
return nullCount, diags
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Unmark the count value, sensitive values are allowed in count but not for_each,
|
||||||
|
// as using it here will not disclose the sensitive value
|
||||||
|
countVal, _ = countVal.Unmark()
|
||||||
|
|
||||||
switch {
|
switch {
|
||||||
case countVal.IsNull():
|
case countVal.IsNull():
|
||||||
diags = diags.Append(&hcl.Diagnostic{
|
diags = diags.Append(&hcl.Diagnostic{
|
||||||
|
45
terraform/eval_count_test.go
Normal file
45
terraform/eval_count_test.go
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
package terraform
|
||||||
|
|
||||||
|
import (
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/davecgh/go-spew/spew"
|
||||||
|
"github.com/hashicorp/hcl/v2"
|
||||||
|
"github.com/hashicorp/hcl/v2/hcltest"
|
||||||
|
"github.com/zclconf/go-cty/cty"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestEvaluateCountExpression(t *testing.T) {
|
||||||
|
tests := map[string]struct {
|
||||||
|
Expr hcl.Expression
|
||||||
|
Count int
|
||||||
|
}{
|
||||||
|
"zero": {
|
||||||
|
hcltest.MockExprLiteral(cty.NumberIntVal(0)),
|
||||||
|
0,
|
||||||
|
},
|
||||||
|
"expression with marked value": {
|
||||||
|
hcltest.MockExprLiteral(cty.NumberIntVal(8).Mark("sensitive")),
|
||||||
|
8,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for name, test := range tests {
|
||||||
|
t.Run(name, func(t *testing.T) {
|
||||||
|
ctx := &MockEvalContext{}
|
||||||
|
ctx.installSimpleEval()
|
||||||
|
countVal, diags := evaluateCountExpression(test.Expr, ctx)
|
||||||
|
|
||||||
|
if len(diags) != 0 {
|
||||||
|
t.Errorf("unexpected diagnostics %s", spew.Sdump(diags))
|
||||||
|
}
|
||||||
|
|
||||||
|
if !reflect.DeepEqual(countVal, test.Count) {
|
||||||
|
t.Errorf(
|
||||||
|
"wrong map value\ngot: %swant: %s",
|
||||||
|
spew.Sdump(countVal), spew.Sdump(test.Count),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user