...
Source file
src/log/slog/attr_test.go
1
2
3
4
5 package slog
6
7 import (
8 "internal/testenv"
9 "testing"
10 "time"
11 )
12
13 func TestAttrNoAlloc(t *testing.T) {
14 testenv.SkipIfOptimizationOff(t)
15
16 var (
17 i int64
18 u uint64
19 f float64
20 b bool
21 s string
22 x any
23 p = &i
24 d time.Duration
25 )
26 a := int(testing.AllocsPerRun(5, func() {
27 i = Int64("key", 1).Value.Int64()
28 u = Uint64("key", 1).Value.Uint64()
29 f = Float64("key", 1).Value.Float64()
30 b = Bool("key", true).Value.Bool()
31 s = String("key", "foo").Value.String()
32 d = Duration("key", d).Value.Duration()
33 x = Any("key", p).Value.Any()
34 }))
35 if a != 0 {
36 t.Errorf("got %d allocs, want zero", a)
37 }
38 _ = u
39 _ = f
40 _ = b
41 _ = s
42 _ = x
43 }
44
View as plain text