2015-01-26 23:23:27 -06:00
|
|
|
package terraform
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
2016-12-14 23:39:13 -06:00
|
|
|
|
2021-05-17 11:30:37 -05:00
|
|
|
"github.com/hashicorp/terraform/internal/dag"
|
2015-01-26 23:23:27 -06:00
|
|
|
)
|
|
|
|
|
2017-01-20 20:07:51 -06:00
|
|
|
// testGraphnotContains is an assertion helper that tests that a node is
|
|
|
|
// NOT contained in the graph.
|
|
|
|
func testGraphNotContains(t *testing.T, g *Graph, name string) {
|
|
|
|
for _, v := range g.Vertices() {
|
|
|
|
if dag.VertexName(v) == name {
|
|
|
|
t.Fatalf(
|
|
|
|
"Expected %q to NOT be in:\n\n%s",
|
|
|
|
name, g.String())
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-12-14 23:39:13 -06:00
|
|
|
// testGraphHappensBefore is an assertion helper that tests that node
|
|
|
|
// A (dag.VertexName value) happens before node B.
|
|
|
|
func testGraphHappensBefore(t *testing.T, g *Graph, A, B string) {
|
2018-09-24 18:25:40 -05:00
|
|
|
t.Helper()
|
2016-12-14 23:39:13 -06:00
|
|
|
// Find the B vertex
|
|
|
|
var vertexB dag.Vertex
|
|
|
|
for _, v := range g.Vertices() {
|
|
|
|
if dag.VertexName(v) == B {
|
|
|
|
vertexB = v
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if vertexB == nil {
|
|
|
|
t.Fatalf(
|
|
|
|
"Expected %q before %q. Couldn't find %q in:\n\n%s",
|
|
|
|
A, B, B, g.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Look at ancestors
|
|
|
|
deps, err := g.Ancestors(vertexB)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("Error: %s in graph:\n\n%s", err, g.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
// Make sure B is in there
|
|
|
|
for _, v := range deps.List() {
|
|
|
|
if dag.VertexName(v) == A {
|
|
|
|
// Success
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
t.Fatalf(
|
|
|
|
"Expected %q before %q in:\n\n%s",
|
|
|
|
A, B, g.String())
|
|
|
|
}
|