terraform: only keep the destroy if we decreased counts
This commit is contained in:
parent
1ed37f0b7f
commit
e68ea0d38f
|
@ -111,16 +111,16 @@ const testBasicGraphBuilderStr = `
|
||||||
|
|
||||||
const testBuiltinGraphBuilderBasicStr = `
|
const testBuiltinGraphBuilderBasicStr = `
|
||||||
aws_instance.db
|
aws_instance.db
|
||||||
aws_instance.db (destroy)
|
aws_instance.db (destroy tainted)
|
||||||
provider.aws
|
provider.aws
|
||||||
aws_instance.db (destroy)
|
aws_instance.db (destroy tainted)
|
||||||
aws_instance.web (destroy)
|
aws_instance.web (destroy tainted)
|
||||||
provider.aws
|
provider.aws
|
||||||
aws_instance.web
|
aws_instance.web
|
||||||
aws_instance.db
|
aws_instance.db
|
||||||
aws_instance.web (destroy)
|
aws_instance.web (destroy tainted)
|
||||||
provider.aws
|
provider.aws
|
||||||
aws_instance.web (destroy)
|
aws_instance.web (destroy tainted)
|
||||||
provider.aws
|
provider.aws
|
||||||
provider.aws
|
provider.aws
|
||||||
`
|
`
|
||||||
|
|
|
@ -440,6 +440,15 @@ func (n *graphNodeResourceDestroy) DestroyInclude(d *ModuleDiff, s *ModuleState)
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Ignore exact matches and the 0'th index. We only care
|
||||||
|
// about if there is a decrease in count.
|
||||||
|
if k == prefix {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if k == prefix+".0" {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
|
||||||
if v.Primary != nil {
|
if v.Primary != nil {
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
|
@ -204,6 +204,101 @@ func TestPruneDestroyTransformer_count(t *testing.T) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestPruneDestroyTransformer_countDec(t *testing.T) {
|
||||||
|
mod := testModule(t, "transform-destroy-basic")
|
||||||
|
|
||||||
|
diff := &Diff{}
|
||||||
|
state := &State{
|
||||||
|
Modules: []*ModuleState{
|
||||||
|
&ModuleState{
|
||||||
|
Path: RootModulePath,
|
||||||
|
Resources: map[string]*ResourceState{
|
||||||
|
"aws_instance.bar.1": &ResourceState{
|
||||||
|
Primary: &InstanceState{},
|
||||||
|
},
|
||||||
|
"aws_instance.bar.2": &ResourceState{
|
||||||
|
Primary: &InstanceState{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
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(testTransformPruneDestroyCountDecStr)
|
||||||
|
if actual != expected {
|
||||||
|
t.Fatalf("bad:\n\n%s", actual)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestPruneDestroyTransformer_countState(t *testing.T) {
|
||||||
|
mod := testModule(t, "transform-destroy-basic")
|
||||||
|
|
||||||
|
diff := &Diff{}
|
||||||
|
state := &State{
|
||||||
|
Modules: []*ModuleState{
|
||||||
|
&ModuleState{
|
||||||
|
Path: RootModulePath,
|
||||||
|
Resources: map[string]*ResourceState{
|
||||||
|
"aws_instance.bar": &ResourceState{
|
||||||
|
Primary: &InstanceState{},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
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(testTransformPruneDestroyCountStateStr)
|
||||||
|
if actual != expected {
|
||||||
|
t.Fatalf("bad:\n\n%s", actual)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const testTransformDestroyBasicStr = `
|
const testTransformDestroyBasicStr = `
|
||||||
aws_instance.bar
|
aws_instance.bar
|
||||||
aws_instance.bar (destroy tainted)
|
aws_instance.bar (destroy tainted)
|
||||||
|
@ -222,44 +317,93 @@ aws_instance.foo (destroy)
|
||||||
|
|
||||||
const testTransformPruneDestroyBasicStr = `
|
const testTransformPruneDestroyBasicStr = `
|
||||||
aws_instance.bar
|
aws_instance.bar
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
aws_instance.foo
|
aws_instance.foo
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
aws_instance.foo
|
aws_instance.foo
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
`
|
`
|
||||||
|
|
||||||
const testTransformPruneDestroyBasicDiffStr = `
|
const testTransformPruneDestroyBasicDiffStr = `
|
||||||
aws_instance.bar
|
aws_instance.bar
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
aws_instance.bar (destroy)
|
aws_instance.bar (destroy)
|
||||||
aws_instance.foo
|
aws_instance.foo
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
aws_instance.bar (destroy)
|
aws_instance.bar (destroy)
|
||||||
aws_instance.foo
|
aws_instance.foo
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
`
|
`
|
||||||
|
|
||||||
const testTransformPruneDestroyCountStr = `
|
const testTransformPruneDestroyCountStr = `
|
||||||
aws_instance.bar
|
aws_instance.bar
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
aws_instance.bar (destroy)
|
aws_instance.bar (destroy)
|
||||||
aws_instance.foo
|
aws_instance.foo
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
aws_instance.bar (destroy)
|
aws_instance.bar (destroy)
|
||||||
aws_instance.foo
|
aws_instance.foo
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
|
`
|
||||||
|
|
||||||
|
const testTransformPruneDestroyCountDecStr = `
|
||||||
|
aws_instance.bar
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
|
aws_instance.bar (destroy)
|
||||||
|
aws_instance.foo
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
|
aws_instance.bar (destroy)
|
||||||
|
aws_instance.foo
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
|
`
|
||||||
|
|
||||||
|
const testTransformPruneDestroyCountStateStr = `
|
||||||
|
aws_instance.bar
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
|
aws_instance.foo
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
|
aws_instance.foo
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.foo (destroy tainted)
|
||||||
|
aws_instance.bar (destroy tainted)
|
||||||
`
|
`
|
||||||
|
|
||||||
const testTransformCreateBeforeDestroyBasicStr = `
|
const testTransformCreateBeforeDestroyBasicStr = `
|
||||||
aws_instance.web
|
aws_instance.web
|
||||||
|
aws_instance.web (destroy tainted)
|
||||||
|
aws_instance.web (destroy tainted)
|
||||||
|
aws_load_balancer.lb (destroy tainted)
|
||||||
aws_instance.web (destroy)
|
aws_instance.web (destroy)
|
||||||
aws_instance.web
|
aws_instance.web
|
||||||
aws_load_balancer.lb
|
aws_load_balancer.lb
|
||||||
aws_load_balancer.lb (destroy)
|
aws_load_balancer.lb (destroy)
|
||||||
aws_load_balancer.lb
|
aws_load_balancer.lb
|
||||||
aws_instance.web
|
aws_instance.web
|
||||||
|
aws_load_balancer.lb (destroy tainted)
|
||||||
aws_load_balancer.lb (destroy)
|
aws_load_balancer.lb (destroy)
|
||||||
|
aws_load_balancer.lb (destroy tainted)
|
||||||
aws_load_balancer.lb (destroy)
|
aws_load_balancer.lb (destroy)
|
||||||
`
|
`
|
||||||
|
|
||||||
const testTransformCreateBeforeDestroyTwiceStr = `
|
const testTransformCreateBeforeDestroyTwiceStr = `
|
||||||
aws_autoscale.bar
|
aws_autoscale.bar
|
||||||
|
aws_autoscale.bar (destroy tainted)
|
||||||
aws_lc.foo
|
aws_lc.foo
|
||||||
|
aws_autoscale.bar (destroy tainted)
|
||||||
aws_autoscale.bar (destroy)
|
aws_autoscale.bar (destroy)
|
||||||
aws_autoscale.bar
|
aws_autoscale.bar
|
||||||
aws_lc.foo
|
aws_lc.foo
|
||||||
|
aws_lc.foo (destroy tainted)
|
||||||
|
aws_lc.foo (destroy tainted)
|
||||||
|
aws_autoscale.bar (destroy tainted)
|
||||||
aws_lc.foo (destroy)
|
aws_lc.foo (destroy)
|
||||||
aws_autoscale.bar
|
aws_autoscale.bar
|
||||||
aws_autoscale.bar (destroy)
|
aws_autoscale.bar (destroy)
|
||||||
|
|
Loading…
Reference in New Issue