Skip to content

Commit

Permalink
terraform: Add support for Terraform v1.5 (#1780)
Browse files Browse the repository at this point in the history
* Add support for Terraform v1.5

* Remove `go:generate` in the terraform package
  • Loading branch information
wata727 authored Jun 18, 2023
1 parent a615362 commit 2c1e47d
Show file tree
Hide file tree
Showing 6 changed files with 134 additions and 2 deletions.
2 changes: 0 additions & 2 deletions terraform/addrs/resource.go
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,6 @@ func (r ResourceInstance) ContainingResource() Resource {
// resource lifecycle has a slightly different address format.
type ResourceMode rune

//go:generate go run golang.org/x/tools/cmd/stringer -type ResourceMode

const (
// InvalidResourceMode is the zero value of ResourceMode and is not
// a valid resource mode.
Expand Down
13 changes: 13 additions & 0 deletions terraform/lang/funcs/datetime.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0

package funcs

import (
Expand All @@ -17,6 +20,16 @@ var TimestampFunc = function.New(&function.Spec{
},
})

// PlantimestampFunc constructs a function that returns the time of the plan.
// TFLint always treats this value as unknown.
var PlantimestampFunc = function.New(&function.Spec{
Params: []function.Parameter{},
Type: function.StaticReturnType(cty.String),
Impl: func(args []cty.Value, retType cty.Type) (cty.Value, error) {
return cty.UnknownVal(cty.String), nil
},
})

// TimeAddFunc constructs a function that adds a duration to a timestamp, returning a new timestamp.
var TimeAddFunc = function.New(&function.Spec{
Params: []function.Parameter{
Expand Down
29 changes: 29 additions & 0 deletions terraform/lang/funcs/string.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0

package funcs

import (
Expand Down Expand Up @@ -103,3 +106,29 @@ var ReplaceFunc = function.New(&function.Spec{
func Replace(str, substr, replace cty.Value) (cty.Value, error) {
return ReplaceFunc.Call([]cty.Value{str, substr, replace})
}

// StrContainsFunc searches a given string for another given substring,
// if found the function returns true, otherwise returns false.
var StrContainsFunc = function.New(&function.Spec{
Params: []function.Parameter{
{
Name: "str",
Type: cty.String,
},
{
Name: "substr",
Type: cty.String,
},
},
Type: function.StaticReturnType(cty.Bool),
Impl: func(args []cty.Value, retType cty.Type) (ret cty.Value, err error) {
str := args[0].AsString()
substr := args[1].AsString()

if strings.Contains(str, substr) {
return cty.True, nil
}

return cty.False, nil
},
})
66 changes: 66 additions & 0 deletions terraform/lang/funcs/string_test.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0

package funcs

import (
Expand Down Expand Up @@ -71,3 +74,66 @@ func TestReplace(t *testing.T) {
})
}
}

func TestStrContains(t *testing.T) {
tests := []struct {
String cty.Value
Substr cty.Value
Want cty.Value
Err bool
}{
{
cty.StringVal("hello"),
cty.StringVal("hel"),
cty.BoolVal(true),
false,
},
{
cty.StringVal("hello"),
cty.StringVal("lo"),
cty.BoolVal(true),
false,
},
{
cty.StringVal("hello1"),
cty.StringVal("1"),
cty.BoolVal(true),
false,
},
{
cty.StringVal("hello1"),
cty.StringVal("heo"),
cty.BoolVal(false),
false,
},
{
cty.StringVal("hello1"),
cty.NumberIntVal(1),
cty.UnknownVal(cty.Bool),
true,
},
}

for _, test := range tests {
t.Run(fmt.Sprintf("includes(%#v, %#v)", test.String, test.Substr), func(t *testing.T) {
got, err := StrContains(test.String, test.Substr)

if test.Err {
if err == nil {
t.Fatal("succeeded; want error")
}
return
} else if err != nil {
t.Fatalf("unexpected error: %s", err)
}

if !got.RawEquals(test.Want) {
t.Errorf("wrong result\ngot: %#v\nwant: %#v", got, test.Want)
}
})
}
}

func StrContains(str, substr cty.Value) (cty.Value, error) {
return StrContainsFunc.Call([]cty.Value{str, substr})
}
5 changes: 5 additions & 0 deletions terraform/lang/functions.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0

package lang

import (
Expand Down Expand Up @@ -93,6 +96,7 @@ func (s *Scope) Functions() map[string]function.Function {
"one": funcs.OneFunc,
"parseint": stdlib.ParseIntFunc,
"pathexpand": funcs.PathExpandFunc,
"plantimestamp": funcs.PlantimestampFunc,
"pow": stdlib.PowFunc,
"range": stdlib.RangeFunc,
"regex": stdlib.RegexFunc,
Expand All @@ -114,6 +118,7 @@ func (s *Scope) Functions() map[string]function.Function {
"sort": stdlib.SortFunc,
"split": stdlib.SplitFunc,
"startswith": funcs.StartsWithFunc,
"strcontains": funcs.StrContainsFunc,
"strrev": stdlib.ReverseFunc,
"substr": stdlib.SubstrFunc,
"sum": funcs.SumFunc,
Expand Down
21 changes: 21 additions & 0 deletions terraform/lang/functions_test.go
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0

package lang

import (
Expand Down Expand Up @@ -638,6 +641,13 @@ func TestFunctions(t *testing.T) {
},
},

"plantimestamp": {
{
`plantimestamp()`,
cty.UnknownVal(cty.String),
},
},

"pow": {
{
`pow(1,0)`,
Expand Down Expand Up @@ -837,6 +847,17 @@ func TestFunctions(t *testing.T) {
},
},

"strcontains": {
{
`strcontains("hello", "llo")`,
cty.BoolVal(true),
},
{
`strcontains("hello", "a")`,
cty.BoolVal(false),
},
},

"strrev": {
{
`strrev("hello world")`,
Expand Down

0 comments on commit 2c1e47d

Please sign in to comment.