mirror of
https://github.com/tailscale/tailscale.git
synced 2025-01-10 18:13:41 +00:00
68b12a74ed
metrics.LabelMap grows slightly more heavy, needing a lock to ensure proper ordering for newly initialized ShardedInt values. An Add method enables callers to use .Add for both expvar.Int and syncs.ShardedInt values, but retains the original behavior of defaulting to initializing expvar.Int values. Updates tailscale/corp#25450 Co-Authored-By: Andrew Dunham <andrew@du.nham.ca> Signed-off-by: James Tucker <james@tailscale.com>
74 lines
1.5 KiB
Go
74 lines
1.5 KiB
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
package metrics
|
|
|
|
import (
|
|
"os"
|
|
"runtime"
|
|
"testing"
|
|
|
|
"tailscale.com/tstest"
|
|
)
|
|
|
|
func TestLabelMap(t *testing.T) {
|
|
var m LabelMap
|
|
m.GetIncrFunc("foo")(1)
|
|
m.GetIncrFunc("bar")(2)
|
|
if g, w := m.Get("foo").Value(), int64(1); g != w {
|
|
t.Errorf("foo = %v; want %v", g, w)
|
|
}
|
|
if g, w := m.Get("bar").Value(), int64(2); g != w {
|
|
t.Errorf("bar = %v; want %v", g, w)
|
|
}
|
|
m.GetShardedInt("sharded").Add(5)
|
|
if g, w := m.GetShardedInt("sharded").Value(), int64(5); g != w {
|
|
t.Errorf("sharded = %v; want %v", g, w)
|
|
}
|
|
m.Add("sharded", 1)
|
|
if g, w := m.GetShardedInt("sharded").Value(), int64(6); g != w {
|
|
t.Errorf("sharded = %v; want %v", g, w)
|
|
}
|
|
m.Add("neverbefore", 1)
|
|
}
|
|
|
|
func TestCurrentFileDescriptors(t *testing.T) {
|
|
if runtime.GOOS != "linux" {
|
|
t.Skipf("skipping on %v", runtime.GOOS)
|
|
}
|
|
n := CurrentFDs()
|
|
if n < 3 {
|
|
t.Fatalf("got %v; want >= 3", n)
|
|
}
|
|
|
|
err := tstest.MinAllocsPerRun(t, 0, func() {
|
|
n = CurrentFDs()
|
|
})
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
// Open some FDs.
|
|
const extra = 10
|
|
for i := range extra {
|
|
f, err := os.Open("/proc/self/stat")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
defer f.Close()
|
|
t.Logf("fds for #%v = %v", i, CurrentFDs())
|
|
}
|
|
|
|
n2 := CurrentFDs()
|
|
if n2 < n+extra {
|
|
t.Errorf("fds changed from %v => %v, want to %v", n, n2, n+extra)
|
|
}
|
|
}
|
|
|
|
func BenchmarkCurrentFileDescriptors(b *testing.B) {
|
|
b.ReportAllocs()
|
|
for range b.N {
|
|
_ = CurrentFDs()
|
|
}
|
|
}
|