2011-10-26 23:57:58 +00:00
|
|
|
package runtime_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"runtime"
|
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestGcSys(t *testing.T) {
|
2011-12-13 23:15:36 +00:00
|
|
|
runtime.GC()
|
|
|
|
runtime.UpdateMemStats()
|
|
|
|
sys := runtime.MemStats.Sys
|
|
|
|
|
2011-10-26 23:57:58 +00:00
|
|
|
for i := 0; i < 1000000; i++ {
|
|
|
|
workthegc()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Should only be using a few MB.
|
|
|
|
runtime.UpdateMemStats()
|
2011-12-13 23:15:36 +00:00
|
|
|
if sys > runtime.MemStats.Sys {
|
|
|
|
sys = 0
|
|
|
|
} else {
|
|
|
|
sys = runtime.MemStats.Sys - sys
|
|
|
|
}
|
|
|
|
t.Logf("used %d extra bytes", sys)
|
2011-12-14 14:54:32 +00:00
|
|
|
if sys > 4<<20 {
|
2011-12-13 23:15:36 +00:00
|
|
|
t.Fatalf("using too much memory: %d bytes", sys)
|
2011-10-26 23:57:58 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func workthegc() []byte {
|
|
|
|
return make([]byte, 1029)
|
|
|
|
}
|