Skip to content

Commit

Permalink
config: multi-variable access in slice validation fixed [GH-798]
Browse files Browse the repository at this point in the history
  • Loading branch information
mitchellh committed Jan 15, 2015
1 parent 5c0fc0c commit a2e40ad
Show file tree
Hide file tree
Showing 3 changed files with 35 additions and 0 deletions.
21 changes: 21 additions & 0 deletions config/config.go
Original file line number Diff line number Diff line change
Expand Up @@ -478,10 +478,31 @@ func (c *Config) rawConfigs() map[string]*RawConfig {
func (c *Config) validateVarContextFn(
source string, errs *[]error) interpolationWalkerContextFunc {
return func(loc reflectwalk.Location, node ast.Node) {
// If we're in a slice element, then its fine, since you can do
// anything in there.
if loc == reflectwalk.SliceElem {
return
}

// Otherwise, let's check if there is a splat resource variable
// at the top level in here. We do this by doing a transform that
// replaces everything with a noop node unless its a variable
// access or concat. This should turn the AST into a flat tree
// of Concat(Noop, ...). If there are any variables left that are
// multi-access, then its still broken.
node = node.Accept(func(n ast.Node) ast.Node {
// If it is a concat or variable access, we allow it.
switch n.(type) {
case *ast.Concat:
return n
case *ast.VariableAccess:
return n
}

// Otherwise, noop
return &noopNode{}
})

vars, err := DetectVariables(node)
if err != nil {
// Ignore it since this will be caught during parse. This
Expand Down
7 changes: 7 additions & 0 deletions config/config_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,13 @@ func TestConfigValidate_varMultiNonSlice(t *testing.T) {
}
}

func TestConfigValidate_varMultiFunctionCall(t *testing.T) {
c := testConfig(t, "validate-var-multi-func")
if err := c.Validate(); err != nil {
t.Fatalf("should be valid: %s", err)
}
}

func TestConfigValidate_varModule(t *testing.T) {
c := testConfig(t, "validate-var-module")
if err := c.Validate(); err != nil {
Expand Down
7 changes: 7 additions & 0 deletions config/test-fixtures/validate-var-multi-func/main.tf
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
resource "aws_instance" "foo" {
count = 3
}

resource "aws_instance" "bar" {
foo = "${element(aws_instance.foo.*.id, 0)}"
}

1 comment on commit a2e40ad

@mitchellh
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Missed file, pushed in this commit: 7f9abbb

Please sign in to comment.