terraform: when pruning destroy, only match exact nodes, or exact counts

This commit is contained in:
Mitchell Hashimoto 2015-04-14 13:17:08 -07:00
parent 173d8df0ed
commit 486cde44ec
3 changed files with 69 additions and 4 deletions

View File

@ -555,20 +555,25 @@ func (n *graphNodeResourceDestroy) destroyIncludePrimary(
// decreases to "1". // decreases to "1".
if s != nil { if s != nil {
for k, v := range s.Resources { for k, v := range s.Resources {
if !strings.HasPrefix(k, prefix) { // Ignore exact matches
if k == prefix {
continue
}
// Ignore anything that doesn't have a "." afterwards so that
// we only get our own resource and any counts on it.
if !strings.HasPrefix(k, prefix+".") {
continue continue
} }
// Ignore exact matches and the 0'th index. We only care // Ignore exact matches and the 0'th index. We only care
// about if there is a decrease in count. // about if there is a decrease in count.
if k == prefix {
continue
}
if k == prefix+".0" { if k == prefix+".0" {
continue continue
} }
if v.Primary != nil { if v.Primary != nil {
println("FUCK: " + prefix + " ; " + k)
return true return true
} }
} }

View File

@ -0,0 +1,3 @@
resource "aws_instance" "foo" {}
resource "aws_instance" "foo-bar" {}

View File

@ -299,6 +299,56 @@ func TestPruneDestroyTransformer_countState(t *testing.T) {
} }
} }
func TestPruneDestroyTransformer_prefixMatch(t *testing.T) {
mod := testModule(t, "transform-destroy-prefix")
diff := &Diff{}
state := &State{
Modules: []*ModuleState{
&ModuleState{
Path: RootModulePath,
Resources: map[string]*ResourceState{
"aws_instance.foo-bar.0": &ResourceState{
Primary: &InstanceState{ID: "foo"},
},
"aws_instance.foo-bar.1": &ResourceState{
Primary: &InstanceState{ID: "foo"},
},
},
},
},
}
g := Graph{Path: RootModulePath}
{
tf := &ConfigTransformer{Module: mod}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
{
tf := &DestroyTransformer{}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
{
tf := &PruneDestroyTransformer{Diff: diff, State: state}
if err := tf.Transform(&g); err != nil {
t.Fatalf("err: %s", err)
}
}
actual := strings.TrimSpace(g.String())
expected := strings.TrimSpace(testTransformPruneDestroyPrefixStr)
if actual != expected {
t.Fatalf("bad:\n\n%s", actual)
}
}
func TestPruneDestroyTransformer_tainted(t *testing.T) { func TestPruneDestroyTransformer_tainted(t *testing.T) {
mod := testModule(t, "transform-destroy-basic") mod := testModule(t, "transform-destroy-basic")
@ -399,6 +449,13 @@ aws_instance.bar
aws_instance.foo aws_instance.foo
` `
const testTransformPruneDestroyPrefixStr = `
aws_instance.foo
aws_instance.foo-bar
aws_instance.foo-bar (destroy)
aws_instance.foo-bar (destroy)
`
const testTransformPruneDestroyTaintedStr = ` const testTransformPruneDestroyTaintedStr = `
aws_instance.bar aws_instance.bar
aws_instance.bar (destroy tainted) aws_instance.bar (destroy tainted)