File: pprof_test.go

package info (click to toggle)
golang-golang-x-tools 1%3A0.25.0%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 22,724 kB
  • sloc: javascript: 2,027; asm: 1,645; sh: 166; yacc: 155; makefile: 49; ansic: 8
file content (46 lines) | stat: -rw-r--r-- 950 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
// Copyright 2023 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 pprof_test

import (
	"bytes"
	"compress/gzip"
	"io"
	"log"
	"os"
	"testing"
	"time"

	"golang.org/x/tools/internal/pprof"
)

func TestTotalTime(t *testing.T) {
	// $ go tool pprof testdata/sample.pprof <&- 2>&1 | grep Total
	// Duration: 11.10s, Total samples = 27.59s (248.65%)
	const (
		filename = "testdata/sample.pprof"
		want     = time.Duration(27590003550)
	)

	profGz, err := os.ReadFile(filename)
	if err != nil {
		t.Fatal(err)
	}
	rd, err := gzip.NewReader(bytes.NewReader(profGz))
	if err != nil {
		t.Fatal(err)
	}
	payload, err := io.ReadAll(rd)
	if err != nil {
		t.Fatal(err)
	}
	got, err := pprof.TotalTime(payload)
	if err != nil {
		log.Fatal(err)
	}
	if got != want {
		t.Fatalf("TotalTime(%q): got %v (%d), want %v (%d)", filename, got, got, want, want)
	}
}