2015-01-26 23:23:27 -06:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
2015-08-10 15:04:48 -05:00
|
|
|
"reflect"
|
2015-01-26 23:23:27 -06:00
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestGraphAdd(t *testing.T) {
|
|
|
|
// Test Add since we override it and want to make sure we don't break it.
|
|
|
|
var g Graph
|
|
|
|
g.Add(42)
|
|
|
|
g.Add(84)
|
|
|
|
|
|
|
|
actual := strings.TrimSpace(g.String())
|
|
|
|
expected := strings.TrimSpace(testGraphAddStr)
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-01-27 16:56:01 -06:00
|
|
|
func TestGraphConnectDependent(t *testing.T) {
|
2015-01-26 23:37:10 -06:00
|
|
|
var g Graph
|
2015-08-10 15:04:48 -05:00
|
|
|
g.Add(&testGraphDependable{VertexName: "a"})
|
2015-01-27 16:56:01 -06:00
|
|
|
b := g.Add(&testGraphDependable{
|
|
|
|
VertexName: "b",
|
|
|
|
DependentOnMock: []string{"a"},
|
|
|
|
})
|
2015-01-26 23:37:10 -06:00
|
|
|
|
2015-01-27 16:56:01 -06:00
|
|
|
if missing := g.ConnectDependent(b); len(missing) > 0 {
|
2015-01-26 23:37:10 -06:00
|
|
|
t.Fatalf("bad: %#v", missing)
|
|
|
|
}
|
|
|
|
|
|
|
|
actual := strings.TrimSpace(g.String())
|
|
|
|
expected := strings.TrimSpace(testGraphConnectDepsStr)
|
|
|
|
if actual != expected {
|
|
|
|
t.Fatalf("bad: %s", actual)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-08-10 15:04:48 -05:00
|
|
|
func TestGraphReplace_DependableWithNonDependable(t *testing.T) {
|
|
|
|
var g Graph
|
|
|
|
a := g.Add(&testGraphDependable{VertexName: "a"})
|
|
|
|
b := g.Add(&testGraphDependable{
|
|
|
|
VertexName: "b",
|
|
|
|
DependentOnMock: []string{"a"},
|
|
|
|
})
|
|
|
|
newA := "non-dependable-a"
|
|
|
|
|
|
|
|
if missing := g.ConnectDependent(b); len(missing) > 0 {
|
|
|
|
t.Fatalf("bad: %#v", missing)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !g.Replace(a, newA) {
|
|
|
|
t.Fatalf("failed to replace")
|
|
|
|
}
|
|
|
|
|
|
|
|
c := g.Add(&testGraphDependable{
|
|
|
|
VertexName: "c",
|
|
|
|
DependentOnMock: []string{"a"},
|
|
|
|
})
|
|
|
|
|
|
|
|
// This should fail by reporting missing, since a node with dependable
|
|
|
|
// name "a" is no longer in the graph.
|
|
|
|
missing := g.ConnectDependent(c)
|
|
|
|
expected := []string{"a"}
|
|
|
|
if !reflect.DeepEqual(expected, missing) {
|
|
|
|
t.Fatalf("expected: %#v, got: %#v", expected, missing)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-11-03 14:04:04 -05:00
|
|
|
func TestGraphWalk_panicWrap(t *testing.T) {
|
|
|
|
var g Graph
|
|
|
|
|
|
|
|
// Add our crasher
|
|
|
|
v := &testGraphSubPath{
|
|
|
|
PathFn: func() []string {
|
|
|
|
panic("yo")
|
|
|
|
},
|
|
|
|
}
|
|
|
|
g.Add(v)
|
|
|
|
|
|
|
|
err := g.Walk(GraphWalkerPanicwrap(new(NullGraphWalker)))
|
|
|
|
if err == nil {
|
|
|
|
t.Fatal("should error")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
type testGraphSubPath struct {
|
|
|
|
PathFn func() []string
|
|
|
|
}
|
|
|
|
|
|
|
|
func (v *testGraphSubPath) Path() []string { return v.PathFn() }
|
|
|
|
|
2015-01-26 23:37:10 -06:00
|
|
|
type testGraphDependable struct {
|
2015-01-27 16:56:01 -06:00
|
|
|
VertexName string
|
|
|
|
DependentOnMock []string
|
2015-01-26 23:37:10 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
func (v *testGraphDependable) Name() string {
|
|
|
|
return v.VertexName
|
|
|
|
}
|
|
|
|
|
|
|
|
func (v *testGraphDependable) DependableName() []string {
|
2015-08-10 15:04:48 -05:00
|
|
|
return []string{v.VertexName}
|
2015-01-26 23:37:10 -06:00
|
|
|
}
|
|
|
|
|
2015-01-27 16:56:01 -06:00
|
|
|
func (v *testGraphDependable) DependentOn() []string {
|
|
|
|
return v.DependentOnMock
|
|
|
|
}
|
|
|
|
|
2015-01-26 23:23:27 -06:00
|
|
|
const testGraphAddStr = `
|
|
|
|
42
|
|
|
|
84
|
|
|
|
`
|
2015-01-26 23:37:10 -06:00
|
|
|
|
|
|
|
const testGraphConnectDepsStr = `
|
|
|
|
a
|
|
|
|
b
|
|
|
|
a
|
|
|
|
`
|