diff --git a/terraform/context_input_test.go b/terraform/context_input_test.go index 08e017b4cc..f953645c89 100644 --- a/terraform/context_input_test.go +++ b/terraform/context_input_test.go @@ -49,6 +49,27 @@ func TestContext2Input(t *testing.T) { } } +func TestContext2Input_moduleComputedOutputElement(t *testing.T) { + m := testModule(t, "input-module-computed-output-element") + p := testProvider("aws") + p.ApplyFn = testApplyFn + p.DiffFn = testDiffFn + ctx := testContext2(t, &ContextOpts{ + Module: m, + Providers: map[string]ResourceProviderFactory{ + "aws": testProviderFuncFixed(p), + }, + }) + + p.InputFn = func(i UIInput, c *ResourceConfig) (*ResourceConfig, error) { + return c, nil + } + + if err := ctx.Input(InputModeStd); err != nil { + t.Fatalf("err: %s", err) + } +} + func TestContext2Input_badVarDefault(t *testing.T) { m := testModule(t, "input-bad-var-default") p := testProvider("aws") diff --git a/terraform/test-fixtures/input-module-computed-output-element/main.tf b/terraform/test-fixtures/input-module-computed-output-element/main.tf new file mode 100644 index 0000000000..bb96e24a3e --- /dev/null +++ b/terraform/test-fixtures/input-module-computed-output-element/main.tf @@ -0,0 +1,9 @@ +module "b" { + source = "./modb" +} + +module "a" { + source = "./moda" + + single_element = "${element(module.b.computed_list, 0)}" +} diff --git a/terraform/test-fixtures/input-module-computed-output-element/moda/main.tf b/terraform/test-fixtures/input-module-computed-output-element/moda/main.tf new file mode 100644 index 0000000000..eb09eb192e --- /dev/null +++ b/terraform/test-fixtures/input-module-computed-output-element/moda/main.tf @@ -0,0 +1,3 @@ +variable "single_element" { + type = "string" +} diff --git a/terraform/test-fixtures/input-module-computed-output-element/modb/main.tf b/terraform/test-fixtures/input-module-computed-output-element/modb/main.tf new file mode 100644 index 0000000000..ebe4a7eff7 --- /dev/null +++ b/terraform/test-fixtures/input-module-computed-output-element/modb/main.tf @@ -0,0 +1,7 @@ +resource "aws_instance" "test" { + count = 3 +} + +output "computed_list" { + value = ["${aws_instance.test.*.id}"] +}