|  | // Copyright 2014 The Go Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style | 
|  | // license that can be found in the LICENSE file. | 
|  |  | 
|  | package debug_test | 
|  |  | 
|  | import ( | 
|  | "io/ioutil" | 
|  | "os" | 
|  | "runtime" | 
|  | . "runtime/debug" | 
|  | "testing" | 
|  | ) | 
|  |  | 
|  | func TestWriteHeapDumpNonempty(t *testing.T) { | 
|  | if runtime.GOOS == "nacl" { | 
|  | t.Skip("WriteHeapDump is not available on NaCl.") | 
|  | } | 
|  | f, err := ioutil.TempFile("", "heapdumptest") | 
|  | if err != nil { | 
|  | t.Fatalf("TempFile failed: %v", err) | 
|  | } | 
|  | defer os.Remove(f.Name()) | 
|  | defer f.Close() | 
|  | WriteHeapDump(f.Fd()) | 
|  | fi, err := f.Stat() | 
|  | if err != nil { | 
|  | t.Fatalf("Stat failed: %v", err) | 
|  | } | 
|  | const minSize = 1 | 
|  | if size := fi.Size(); size < minSize { | 
|  | t.Fatalf("Heap dump size %d bytes, expected at least %d bytes", size, minSize) | 
|  | } | 
|  | } | 
|  |  | 
|  | type Obj struct { | 
|  | x, y int | 
|  | } | 
|  |  | 
|  | func objfin(x *Obj) { | 
|  | //println("finalized", x) | 
|  | } | 
|  |  | 
|  | func TestWriteHeapDumpFinalizers(t *testing.T) { | 
|  | if runtime.GOOS == "nacl" { | 
|  | t.Skip("WriteHeapDump is not available on NaCl.") | 
|  | } | 
|  | f, err := ioutil.TempFile("", "heapdumptest") | 
|  | if err != nil { | 
|  | t.Fatalf("TempFile failed: %v", err) | 
|  | } | 
|  | defer os.Remove(f.Name()) | 
|  | defer f.Close() | 
|  |  | 
|  | // bug 9172: WriteHeapDump couldn't handle more than one finalizer | 
|  | println("allocating objects") | 
|  | x := &Obj{} | 
|  | runtime.SetFinalizer(x, objfin) | 
|  | y := &Obj{} | 
|  | runtime.SetFinalizer(y, objfin) | 
|  |  | 
|  | // Trigger collection of x and y, queueing of their finalizers. | 
|  | println("starting gc") | 
|  | runtime.GC() | 
|  |  | 
|  | // Make sure WriteHeapDump doesn't fail with multiple queued finalizers. | 
|  | println("starting dump") | 
|  | WriteHeapDump(f.Fd()) | 
|  | println("done dump") | 
|  | } |