From 0ab0ccf5b3eb17af35d17af63ea3fb735b5decf3 Mon Sep 17 00:00:00 2001 From: Mitchell Hashimoto Date: Thu, 28 Apr 2016 19:28:23 +0200 Subject: [PATCH] terraform: verify refresh is called on import --- terraform/context_import_test.go | 48 ++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) diff --git a/terraform/context_import_test.go b/terraform/context_import_test.go index eee2151dd..76727a424 100644 --- a/terraform/context_import_test.go +++ b/terraform/context_import_test.go @@ -39,8 +39,56 @@ func TestContextImport_basic(t *testing.T) { } } +func TestContextImport_refresh(t *testing.T) { + p := testProvider("aws") + ctx := testContext2(t, &ContextOpts{ + Providers: map[string]ResourceProviderFactory{ + "aws": testProviderFuncFixed(p), + }, + }) + + p.ImportStateReturn = []*InstanceState{ + &InstanceState{ + ID: "foo", + Ephemeral: EphemeralState{Type: "aws_instance"}, + }, + } + + p.RefreshFn = func(info *InstanceInfo, s *InstanceState) (*InstanceState, error) { + return &InstanceState{ + ID: "foo", + Attributes: map[string]string{"foo": "bar"}, + }, nil + } + + state, err := ctx.Import(&ImportOpts{ + Targets: []*ImportTarget{ + &ImportTarget{ + Addr: "aws_instance.foo", + ID: "bar", + }, + }, + }) + if err != nil { + t.Fatalf("err: %s", err) + } + + actual := strings.TrimSpace(state.String()) + expected := strings.TrimSpace(testImportRefreshStr) + if actual != expected { + t.Fatalf("bad: \n%s", actual) + } +} + const testImportStr = ` aws_instance.foo: ID = foo provider = aws ` + +const testImportRefreshStr = ` +aws_instance.foo: + ID = foo + provider = aws + foo = bar +`