diff --git a/cmd/callgraph/main_test.go b/cmd/callgraph/main_test.go index cd9838a5e7..c8bee87e2b 100644 --- a/cmd/callgraph/main_test.go +++ b/cmd/callgraph/main_test.go @@ -59,6 +59,12 @@ func TestCallgraph(t *testing.T) { `pkg.main2 --> (pkg.C).f`, `pkg.main2 --> (pkg.D).f`, }}, + {"vta", false, []string{ + // vta distinguishes main->C, main2->D. + "pkg.main --> (pkg.C).f", + "pkg.main --> pkg.main2", + "pkg.main2 --> (pkg.D).f", + }}, {"pta", false, []string{ // pta distinguishes main->C, main2->D. Also has a root node. ` --> pkg.init`, @@ -75,6 +81,12 @@ func TestCallgraph(t *testing.T) { `pkg.Example --> (pkg.C).f`, `pkg.main --> (pkg.C).f`, }}, + {"vta", true, []string{ + `pkg.test.main --> testing.MainStart`, + `testing.runExample --> pkg.Example`, + `pkg.Example --> (pkg.C).f`, + `pkg.main --> (pkg.C).f`, + }}, {"pta", true, []string{ ` --> pkg.test.main`, ` --> pkg.main`, @@ -95,13 +107,15 @@ func TestCallgraph(t *testing.T) { for _, line := range strings.Split(fmt.Sprint(stdout), "\n") { edges[line] = true } + ok := true for _, edge := range test.want { if !edges[edge] { + ok = false t.Errorf("callgraph(%q, %t): missing edge: %s", test.algo, test.tests, edge) } } - if t.Failed() { + if !ok { t.Log("got:\n", stdout) } }