terraform: convert empty path to root path in V1 state

This commit is contained in:
Mitchell Hashimoto 2017-03-21 11:37:12 -07:00
parent 8b3550d714
commit 69759e04ca
No known key found for this signature in database
GPG Key ID: 744E147AA52F5B0A
3 changed files with 67 additions and 3 deletions

View File

@ -64,11 +64,15 @@ func (old *moduleStateV1) upgradeToV2() (*ModuleState, error) {
return nil, nil
}
path, err := copystructure.Copy(old.Path)
pathRaw, err := copystructure.Copy(old.Path)
if err != nil {
return nil, fmt.Errorf("Error upgrading ModuleState V1: %v", err)
}
if path == nil {
path, ok := pathRaw.([]string)
if !ok {
return nil, fmt.Errorf("Error upgrading ModuleState V1: path is not a list of strings")
}
if len(path) == 0 {
// We found some V1 states with a nil path. Assume root and catch
// duplicate path errors later (as part of Validate).
path = rootModulePath
@ -99,7 +103,7 @@ func (old *moduleStateV1) upgradeToV2() (*ModuleState, error) {
}
return &ModuleState{
Path: path.([]string),
Path: path,
Outputs: outputs,
Resources: resources,
Dependencies: dependencies.([]string),

View File

@ -0,0 +1,22 @@
package terraform
import (
"os"
"path/filepath"
"testing"
)
func TestReadStateV1ToV2_noPath(t *testing.T) {
f, err := os.Open(filepath.Join(fixtureDir, "state-upgrade", "v1-to-v2-empty-path.tfstate"))
if err != nil {
t.Fatalf("err: %s", err)
}
defer f.Close()
s, err := ReadState(f)
if err != nil {
t.Fatalf("err: %s", err)
}
checkStateString(t, s, "<no state>")
}

View File

@ -0,0 +1,38 @@
{
"version": 1,
"modules": [{
"resources": {
"aws_instance.foo1": {"primary":{}},
"cloudstack_instance.foo1": {"primary":{}},
"cloudstack_instance.foo2": {"primary":{}},
"digitalocean_droplet.foo1": {"primary":{}},
"digitalocean_droplet.foo2": {"primary":{}},
"digitalocean_droplet.foo3": {"primary":{}},
"docker_container.foo1": {"primary":{}},
"docker_container.foo2": {"primary":{}},
"docker_container.foo3": {"primary":{}},
"docker_container.foo4": {"primary":{}},
"google_compute_instance.foo1": {"primary":{}},
"google_compute_instance.foo2": {"primary":{}},
"google_compute_instance.foo3": {"primary":{}},
"google_compute_instance.foo4": {"primary":{}},
"google_compute_instance.foo5": {"primary":{}},
"heroku_app.foo1": {"primary":{}},
"heroku_app.foo2": {"primary":{}},
"heroku_app.foo3": {"primary":{}},
"heroku_app.foo4": {"primary":{}},
"heroku_app.foo5": {"primary":{}},
"heroku_app.foo6": {"primary":{}},
"openstack_compute_instance_v2.foo1": {"primary":{}},
"openstack_compute_instance_v2.foo2": {"primary":{}},
"openstack_compute_instance_v2.foo3": {"primary":{}},
"openstack_compute_instance_v2.foo4": {"primary":{}},
"openstack_compute_instance_v2.foo5": {"primary":{}},
"openstack_compute_instance_v2.foo6": {"primary":{}},
"openstack_compute_instance_v2.foo7": {"primary":{}},
"bar": {"primary":{}},
"baz": {"primary":{}},
"zip": {"primary":{}}
}
}]
}