blob: cb6c0e57ba598c965b320869e2ec9473717d2697 [file] [log] [blame]
// Copyright 2018 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 xerrors_test
import (
"bytes"
"fmt"
"math/big"
"testing"
"golang.org/x/xerrors"
"golang.org/x/xerrors/internal"
)
type myType struct{}
func (myType) Format(s fmt.State, v rune) {
s.Write(bytes.Repeat([]byte("Hi! "), 10))
}
func BenchmarkErrorf(b *testing.B) {
err := xerrors.New("foo")
// pi := big.NewFloat(3.14) // Something expensive.
num := big.NewInt(5)
args := func(a ...any) []any { return a }
benchCases := []struct {
name string
format string
args []any
}{
{"no_format", "msg: %v", args(err)},
{"with_format", "failed %d times: %v", args(5, err)},
{"method: mytype", "pi: %v", args("myfile.go", myType{}, err)},
{"method: number", "pi: %v", args("myfile.go", num, err)},
}
for _, bc := range benchCases {
b.Run(bc.name, func(b *testing.B) {
b.Run("ExpWithTrace", func(b *testing.B) {
for i := 0; i < b.N; i++ {
xerrors.Errorf(bc.format, bc.args...)
}
})
b.Run("ExpNoTrace", func(b *testing.B) {
internal.EnableTrace = false
defer func() { internal.EnableTrace = true }()
for i := 0; i < b.N; i++ {
xerrors.Errorf(bc.format, bc.args...)
}
})
b.Run("Core", func(b *testing.B) {
for i := 0; i < b.N; i++ {
fmt.Errorf(bc.format, bc.args...)
}
})
})
}
}