From 52a95c3e97c302d7a4adfa2362414bdcbfe882cb Mon Sep 17 00:00:00 2001 From: Kazuma Watanabe Date: Thu, 2 Jan 2025 06:30:38 +0000 Subject: [PATCH] `issensitive` must return unknown for unknown args without `sensitive` Follow up of https://github.com/hashicorp/terraform/pull/36012 --- terraform/lang/funcs/sensitive.go | 10 ++++++++-- terraform/lang/funcs/sensitive_test.go | 20 ++++++++++---------- 2 files changed, 18 insertions(+), 12 deletions(-) diff --git a/terraform/lang/funcs/sensitive.go b/terraform/lang/funcs/sensitive.go index 52f01eca4..2c423b7b9 100644 --- a/terraform/lang/funcs/sensitive.go +++ b/terraform/lang/funcs/sensitive.go @@ -70,8 +70,14 @@ var IssensitiveFunc = function.New(&function.Spec{ return cty.Bool, nil }, Impl: func(args []cty.Value, retType cty.Type) (cty.Value, error) { - s := args[0].HasMark(marks.Sensitive) - return cty.BoolVal(s), nil + switch v := args[0]; { + case v.HasMark(marks.Sensitive): + return cty.True, nil + case !v.IsKnown(): + return cty.UnknownVal(cty.Bool), nil + default: + return cty.False, nil + } }, }) diff --git a/terraform/lang/funcs/sensitive_test.go b/terraform/lang/funcs/sensitive_test.go index 63f322a45..13e6a599f 100644 --- a/terraform/lang/funcs/sensitive_test.go +++ b/terraform/lang/funcs/sensitive_test.go @@ -166,47 +166,47 @@ func TestNonsensitive(t *testing.T) { func TestIssensitive(t *testing.T) { tests := []struct { Input cty.Value - Sensitive bool + Sensitive cty.Value WantErr string }{ { cty.NumberIntVal(1).Mark(marks.Sensitive), - true, + cty.True, ``, }, { cty.NumberIntVal(1), - false, + cty.False, ``, }, { cty.DynamicVal.Mark(marks.Sensitive), - true, + cty.True, ``, }, { cty.UnknownVal(cty.String).Mark(marks.Sensitive), - true, + cty.True, ``, }, { cty.NullVal(cty.EmptyObject).Mark(marks.Sensitive), - true, + cty.True, ``, }, { cty.NullVal(cty.String), - false, + cty.False, ``, }, { cty.DynamicVal, - false, + cty.UnknownVal(cty.Bool), ``, }, { cty.UnknownVal(cty.String), - false, + cty.UnknownVal(cty.Bool), ``, }, } @@ -227,7 +227,7 @@ func TestIssensitive(t *testing.T) { t.Fatalf("unexpected error: %s", err) } - if (got.True() && !test.Sensitive) || (got.False() && test.Sensitive) { + if !got.RawEquals(test.Sensitive) { t.Errorf("wrong result \ngot: %#v\nwant: %#v", got, test.Sensitive) } })