2020-09-14 15:53:37 -05:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
2021-05-17 14:00:50 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/addrs"
|
2021-05-17 14:17:09 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/configs/configschema"
|
2021-05-17 12:40:40 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/providers"
|
2021-05-17 14:43:35 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/states"
|
2020-09-14 15:53:37 -05:00
|
|
|
"github.com/zclconf/go-cty/cty"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestGraphNodeImportStateExecute(t *testing.T) {
|
|
|
|
state := states.NewState()
|
|
|
|
provider := testProvider("aws")
|
2021-01-09 14:33:38 -06:00
|
|
|
provider.ImportResourceStateResponse = &providers.ImportResourceStateResponse{
|
2020-11-13 13:58:59 -06:00
|
|
|
ImportedResources: []providers.ImportedResource{
|
|
|
|
{
|
|
|
|
TypeName: "aws_instance",
|
|
|
|
State: cty.ObjectVal(map[string]cty.Value{
|
|
|
|
"id": cty.StringVal("bar"),
|
|
|
|
}),
|
|
|
|
},
|
2020-09-14 15:53:37 -05:00
|
|
|
},
|
|
|
|
}
|
2020-11-13 13:58:59 -06:00
|
|
|
|
2020-09-14 15:53:37 -05:00
|
|
|
ctx := &MockEvalContext{
|
|
|
|
StateState: state.SyncWrapper(),
|
|
|
|
ProviderProvider: provider,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Import a new aws_instance.foo, this time with ID=bar. The original
|
|
|
|
// aws_instance.foo object should be removed from state and replaced with
|
|
|
|
// the new.
|
|
|
|
node := graphNodeImportState{
|
|
|
|
Addr: addrs.Resource{
|
|
|
|
Mode: addrs.ManagedResourceMode,
|
|
|
|
Type: "aws_instance",
|
|
|
|
Name: "foo",
|
|
|
|
}.Instance(addrs.NoKey).Absolute(addrs.RootModuleInstance),
|
|
|
|
ID: "bar",
|
|
|
|
ResolvedProvider: addrs.AbsProviderConfig{
|
|
|
|
Provider: addrs.NewDefaultProvider("aws"),
|
|
|
|
Module: addrs.RootModule,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
2020-10-28 12:47:04 -05:00
|
|
|
diags := node.Execute(ctx, walkImport)
|
|
|
|
if diags.HasErrors() {
|
|
|
|
t.Fatalf("Unexpected error: %s", diags.Err())
|
2020-09-14 15:53:37 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
if len(node.states) != 1 {
|
|
|
|
t.Fatalf("Wrong result! Expected one imported resource, got %d", len(node.states))
|
|
|
|
}
|
|
|
|
// Verify the ID for good measure
|
|
|
|
id := node.states[0].State.GetAttr("id")
|
|
|
|
if !id.RawEquals(cty.StringVal("bar")) {
|
|
|
|
t.Fatalf("Wrong result! Expected id \"bar\", got %q", id.AsString())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestGraphNodeImportStateSubExecute(t *testing.T) {
|
|
|
|
state := states.NewState()
|
|
|
|
provider := testProvider("aws")
|
|
|
|
ctx := &MockEvalContext{
|
|
|
|
StateState: state.SyncWrapper(),
|
|
|
|
ProviderProvider: provider,
|
|
|
|
ProviderSchemaSchema: &ProviderSchema{
|
|
|
|
ResourceTypes: map[string]*configschema.Block{
|
|
|
|
"aws_instance": {
|
|
|
|
Attributes: map[string]*configschema.Attribute{
|
|
|
|
"id": {
|
|
|
|
Type: cty.String,
|
|
|
|
Computed: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
importedResource := providers.ImportedResource{
|
|
|
|
TypeName: "aws_instance",
|
|
|
|
State: cty.ObjectVal(map[string]cty.Value{"id": cty.StringVal("bar")}),
|
|
|
|
}
|
|
|
|
|
|
|
|
node := graphNodeImportStateSub{
|
|
|
|
TargetAddr: addrs.Resource{
|
|
|
|
Mode: addrs.ManagedResourceMode,
|
|
|
|
Type: "aws_instance",
|
|
|
|
Name: "foo",
|
|
|
|
}.Instance(addrs.NoKey).Absolute(addrs.RootModuleInstance),
|
|
|
|
State: importedResource,
|
|
|
|
ResolvedProvider: addrs.AbsProviderConfig{
|
|
|
|
Provider: addrs.NewDefaultProvider("aws"),
|
|
|
|
Module: addrs.RootModule,
|
|
|
|
},
|
|
|
|
}
|
2020-10-28 12:47:04 -05:00
|
|
|
diags := node.Execute(ctx, walkImport)
|
|
|
|
if diags.HasErrors() {
|
|
|
|
t.Fatalf("Unexpected error: %s", diags.Err())
|
2020-09-14 15:53:37 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
// check for resource in state
|
|
|
|
actual := strings.TrimSpace(state.String())
|
|
|
|
expected := `aws_instance.foo:
|
|
|
|
ID = bar
|
|
|
|
provider = provider["registry.terraform.io/hashicorp/aws"]`
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad state after import: \n%s", actual)
|
|
|
|
}
|
|
|
|
}
|
2021-05-25 16:06:25 -05:00
|
|
|
|
|
|
|
func TestGraphNodeImportStateSubExecuteNull(t *testing.T) {
|
|
|
|
state := states.NewState()
|
|
|
|
provider := testProvider("aws")
|
|
|
|
provider.ReadResourceFn = func(req providers.ReadResourceRequest) (resp providers.ReadResourceResponse) {
|
|
|
|
// return null indicating that the requested resource does not exist
|
|
|
|
resp.NewState = cty.NullVal(cty.Object(map[string]cty.Type{
|
|
|
|
"id": cty.String,
|
|
|
|
}))
|
|
|
|
return resp
|
|
|
|
}
|
|
|
|
|
|
|
|
ctx := &MockEvalContext{
|
|
|
|
StateState: state.SyncWrapper(),
|
|
|
|
ProviderProvider: provider,
|
|
|
|
ProviderSchemaSchema: &ProviderSchema{
|
|
|
|
ResourceTypes: map[string]*configschema.Block{
|
|
|
|
"aws_instance": {
|
|
|
|
Attributes: map[string]*configschema.Attribute{
|
|
|
|
"id": {
|
|
|
|
Type: cty.String,
|
|
|
|
Computed: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
importedResource := providers.ImportedResource{
|
|
|
|
TypeName: "aws_instance",
|
|
|
|
State: cty.ObjectVal(map[string]cty.Value{"id": cty.StringVal("bar")}),
|
|
|
|
}
|
|
|
|
|
|
|
|
node := graphNodeImportStateSub{
|
|
|
|
TargetAddr: addrs.Resource{
|
|
|
|
Mode: addrs.ManagedResourceMode,
|
|
|
|
Type: "aws_instance",
|
|
|
|
Name: "foo",
|
|
|
|
}.Instance(addrs.NoKey).Absolute(addrs.RootModuleInstance),
|
|
|
|
State: importedResource,
|
|
|
|
ResolvedProvider: addrs.AbsProviderConfig{
|
|
|
|
Provider: addrs.NewDefaultProvider("aws"),
|
|
|
|
Module: addrs.RootModule,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
diags := node.Execute(ctx, walkImport)
|
|
|
|
if !diags.HasErrors() {
|
|
|
|
t.Fatal("expected error for non-existent resource")
|
|
|
|
}
|
|
|
|
}
|