github.com/cockroachdb/cockroach@v20.2.0-alpha.1+incompatible/pkg/server/debug/goroutineui/dump_test.go (about) 1 // Copyright 2019 The Cockroach Authors. 2 // 3 // Use of this software is governed by the Business Source License 4 // included in the file licenses/BSL.txt. 5 // 6 // As of the Change Date specified in that file, in accordance with 7 // the Business Source License, use of this software will be governed 8 // by the Apache License, Version 2.0, included in the file 9 // licenses/APL.txt. 10 11 package goroutineui 12 13 import ( 14 "io/ioutil" 15 "testing" 16 "time" 17 18 "github.com/cockroachdb/cockroach/pkg/util/leaktest" 19 "github.com/stretchr/testify/assert" 20 ) 21 22 func TestDumpHTML(t *testing.T) { 23 defer leaktest.AfterTest(t)() 24 25 now := time.Time{} 26 dump := NewDumpFromBytes(now, []byte(fixture)) 27 dump.SortWaitDesc() // noop 28 dump.SortCountDesc() // noop 29 act := dump.HTMLString() 30 31 if false { 32 _ = ioutil.WriteFile("test.html", []byte(act), 0644) 33 } 34 assert.Equal(t, exp, act) 35 } 36 37 // This is the output of debug.PrintStack() on the go playground. 38 const fixture = `goroutine 1 [running]: 39 runtime/debug.Stack(0x434070, 0xddb11, 0x0, 0x40e0f8) 40 /usr/local/go/src/runtime/debug/stack.go:24 +0xc0 41 runtime/debug.PrintStack() 42 /usr/local/go/src/runtime/debug/stack.go:16 +0x20 43 main.main() 44 /tmp/sandbox157492124/main.go:6 +0x20` 45 46 const exp = `<!DOCTYPE html><meta charset="UTF-8"> 47 <meta name="viewport" content="width=device-width, initial-scale=1"> 48 <title>PanicParse</title> 49 <link rel="shortcut icon" type="image/png" href=""/> 50 <style> 51 body { 52 background: black; 53 color: lightgray; 54 } 55 body, pre { 56 font-family: Menlo, monospace; 57 font-weight: bold; 58 } 59 .FuncStdLibExported { 60 color: #7CFC00; 61 } 62 .FuncStdLib { 63 color: #008000; 64 } 65 .FuncMain { 66 color: #C0C000; 67 } 68 .FuncOtherExported { 69 color: #FF0000; 70 } 71 .FuncOther { 72 color: #A00000; 73 } 74 .RoutineFirst { 75 } 76 .Routine { 77 } 78 </style> 79 <div id="legend">Generated on 0001-01-01 00:00:00 +0000 UTC. 80 </div> 81 <div id="content"> 82 83 <h1>Running Routine</h1> 84 <span class="Routine">1: <span class="state">running</span> 85 86 <h2>Stack</h2> 87 88 - stack.go:24 <span class="FuncStdLibExported">Stack</span>({[{4407408 } {908049 } {0 } {4251896 }] [] false})<br> 89 - stack.go:16 <span class="FuncStdLibExported">PrintStack</span>({[] [] false})<br> 90 - .:0 <span class="FuncMain">main</span>({[] [] false})<br> 91 92 93 </div> 94 `