From: Brad Fitzpatrick Date: Thu, 8 Aug 2013 22:25:15 +0000 (-0700) Subject: cmd/api: add a benchmark over the standard library X-Git-Tag: go1.2rc2~711 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=b379b32f31b13381308887fcf02ca52b937a0f07;p=gostls13.git cmd/api: add a benchmark over the standard library R=golang-dev, gri CC=golang-dev https://golang.org/cl/12603045 --- diff --git a/src/cmd/api/goapi_test.go b/src/cmd/api/goapi_test.go index a1e762bafc..b909c32b34 100644 --- a/src/cmd/api/goapi_test.go +++ b/src/cmd/api/goapi_test.go @@ -10,8 +10,10 @@ import ( "bytes" "flag" "fmt" + "go/build" "io/ioutil" "os" + "os/exec" "path/filepath" "sort" "strings" @@ -139,3 +141,28 @@ func TestCompareAPI(t *testing.T) { } } } + +func BenchmarkAll(b *testing.B) { + stds, err := exec.Command("go", "list", "std").Output() + if err != nil { + b.Fatal(err) + } + b.ResetTimer() + pkgNames := strings.Fields(string(stds)) + + for _, c := range contexts { + c.Compiler = build.Default.Compiler + } + + for i := 0; i < b.N; i++ { + for _, context := range contexts { + w := NewWalker(context, filepath.Join(build.Default.GOROOT, "src/pkg")) + for _, name := range pkgNames { + if name != "unsafe" && !strings.HasPrefix(name, "cmd/") { + w.export(w.Import(name)) + } + } + w.Features() + } + } +}