2020-07-01 08:43:07 -05:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/hashicorp/hcl/v2"
|
|
|
|
"github.com/hashicorp/hcl/v2/hclsyntax"
|
|
|
|
"github.com/hashicorp/terraform/addrs"
|
|
|
|
"github.com/hashicorp/terraform/providers"
|
|
|
|
"github.com/zclconf/go-cty/cty"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestContextEval(t *testing.T) {
|
|
|
|
// This test doesn't check the "Want" value for impure funcs, so the value
|
|
|
|
// on those doesn't matter.
|
|
|
|
tests := []struct {
|
|
|
|
Input string
|
|
|
|
Want cty.Value
|
|
|
|
ImpureFunc bool
|
|
|
|
}{
|
|
|
|
{ // An impure function: allowed in the console, but the result is nondeterministic
|
|
|
|
`bcrypt("example")`,
|
|
|
|
cty.NilVal,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
`keys(var.map)`,
|
|
|
|
cty.ListVal([]cty.Value{
|
|
|
|
cty.StringVal("foo"),
|
|
|
|
cty.StringVal("baz"),
|
|
|
|
}),
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
`local.result`,
|
|
|
|
cty.NumberIntVal(6),
|
|
|
|
false,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
`module.child.result`,
|
2020-10-06 16:14:53 -05:00
|
|
|
cty.NumberIntVal(6),
|
2020-07-01 08:43:07 -05:00
|
|
|
false,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
// This module has a little bit of everything (and if it is missing somehitng, add to it):
|
|
|
|
// resources, variables, locals, modules, output
|
|
|
|
m := testModule(t, "eval-context-basic")
|
|
|
|
p := testProvider("test")
|
|
|
|
ctx := testContext2(t, &ContextOpts{
|
|
|
|
Config: m,
|
|
|
|
Providers: map[addrs.Provider]providers.Factory{
|
|
|
|
addrs.NewDefaultProvider("test"): testProviderFuncFixed(p),
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
scope, diags := ctx.Eval(addrs.RootModuleInstance)
|
|
|
|
if diags.HasErrors() {
|
|
|
|
t.Fatalf("Eval errors: %s", diags.Err())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Since we're testing 'eval' (used by terraform console), impure functions
|
|
|
|
// should be allowed by the scope.
|
|
|
|
if scope.PureOnly == true {
|
|
|
|
t.Fatal("wrong result: eval should allow impure funcs")
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, test := range tests {
|
|
|
|
t.Run(test.Input, func(t *testing.T) {
|
|
|
|
// Parse the test input as an expression
|
|
|
|
expr, _ := hclsyntax.ParseExpression([]byte(test.Input), "<test-input>", hcl.Pos{Line: 1, Column: 1})
|
|
|
|
got, diags := scope.EvalExpr(expr, cty.DynamicPseudoType)
|
|
|
|
|
|
|
|
if diags.HasErrors() {
|
|
|
|
t.Fatalf("unexpected error: %s", diags.Err())
|
|
|
|
}
|
|
|
|
|
|
|
|
if !test.ImpureFunc {
|
|
|
|
if !got.RawEquals(test.Want) {
|
|
|
|
t.Fatalf("wrong result: want %#v, got %#v", test.Want, got)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|