1
0
mirror of https://github.com/golang/go synced 2024-11-11 21:20:21 -07:00

runtime/pprof: skip trace tests on solaris and windows

Coarse-grained test skips to fix bots.
Need to look closer at windows and nacl failures.

Change-Id: I767ef1707232918636b33f715459ee3c0349b45e
Reviewed-on: https://go-review.googlesource.com/3416
Reviewed-by: Aram Hăvărneanu <aram@mgk.ro>
Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
This commit is contained in:
Dmitry Vyukov 2015-01-28 20:08:54 +03:00
parent 22c16b4b92
commit 4737399bd9

View File

@ -16,7 +16,21 @@ import (
"time" "time"
) )
func skipTraceTestsIfNeeded(t *testing.T) {
switch runtime.GOOS {
case "solaris":
t.Skip("skipping: solaris timer can go backwards which is incompatible with tracer (http://golang.org/issue/8976)")
case "windows":
t.Skip("skipping: windows tests fail with 'failed to parse trace: no traceEvFrequency event'")
case "android":
t.Skip("skipping: android tests fail with 'failed to parse trace: g 2 is not runnable before traceEvGoWaiting'")
case "plan9":
t.Skip("skipping: plan9 tests fail with 'fatal error: trace: out of memory'")
}
}
func TestTraceStartStop(t *testing.T) { func TestTraceStartStop(t *testing.T) {
skipTraceTestsIfNeeded(t)
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
if err := StartTrace(buf); err != nil { if err := StartTrace(buf); err != nil {
t.Fatalf("failed to start tracing: %v", err) t.Fatalf("failed to start tracing: %v", err)
@ -33,6 +47,7 @@ func TestTraceStartStop(t *testing.T) {
} }
func TestTraceDoubleStart(t *testing.T) { func TestTraceDoubleStart(t *testing.T) {
skipTraceTestsIfNeeded(t)
StopTrace() StopTrace()
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
if err := StartTrace(buf); err != nil { if err := StartTrace(buf); err != nil {
@ -46,6 +61,7 @@ func TestTraceDoubleStart(t *testing.T) {
} }
func TestTrace(t *testing.T) { func TestTrace(t *testing.T) {
skipTraceTestsIfNeeded(t)
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
if err := StartTrace(buf); err != nil { if err := StartTrace(buf); err != nil {
t.Fatalf("failed to start tracing: %v", err) t.Fatalf("failed to start tracing: %v", err)
@ -58,6 +74,8 @@ func TestTrace(t *testing.T) {
} }
func TestTraceStress(t *testing.T) { func TestTraceStress(t *testing.T) {
skipTraceTestsIfNeeded(t)
var wg sync.WaitGroup var wg sync.WaitGroup
done := make(chan bool) done := make(chan bool)
@ -188,6 +206,10 @@ func TestTraceStress(t *testing.T) {
} }
func TestTraceSymbolize(t *testing.T) { func TestTraceSymbolize(t *testing.T) {
skipTraceTestsIfNeeded(t)
if runtime.GOOS == "nacl" {
t.Skip("skipping: nacl tests fail with 'failed to symbolize trace: failed to start addr2line'")
}
buf := new(bytes.Buffer) buf := new(bytes.Buffer)
if err := StartTrace(buf); err != nil { if err := StartTrace(buf); err != nil {
t.Fatalf("failed to start tracing: %v", err) t.Fatalf("failed to start tracing: %v", err)
@ -211,7 +233,7 @@ eventLoop:
for _, f := range ev.stk { for _, f := range ev.stk {
if strings.HasSuffix(f.file, "trace_test.go") && if strings.HasSuffix(f.file, "trace_test.go") &&
strings.HasSuffix(f.fn, "pprof_test.TestTraceSymbolize") && strings.HasSuffix(f.fn, "pprof_test.TestTraceSymbolize") &&
f.line == 195 { f.line == 217 {
found = true found = true
break eventLoop break eventLoop
} }