package zaputil
import (
"fmt"
"math"
"testing"
"go.uber.org/zap"
"go.uber.org/zap/zapcore"
"github.com/stretchr/testify/require"
)
func TestRoomSampleRate(t *testing.T) {
expectedRate := 0.50
n := 10000
c := &testCore{Core: zap.NewExample().Core()}
s := zap.New(NewFieldSampler(c, FieldSamplerConfig{
FieldName: "field",
Rate: NewAtomicFieldSampleRate(expectedRate),
})).Sugar()
for i := 0; i < n; i++ {
s.Debugw("test", "field", fmt.Sprintf("field_%d", i))
}
rate := float64(c.WriteCount()) / float64(n)
require.Greater(t, 0.01, math.Abs(rate-expectedRate))
}
func TestRoomSamplerWith(t *testing.T) {
c := &testCore{Core: zap.NewExample().Core()}
s := zap.New(NewFieldSampler(c, FieldSamplerConfig{
FieldName: "field",
Rate: NewAtomicFieldSampleRate(0),
}).(*fieldSampler)).Sugar()
s.Debugw("test", "field", "test")
require.Equal(t, 0, c.WriteCount())
s.With("field", "test").Debugw("test")
require.Equal(t, 0, c.WriteCount())
}
func TestRoomSampleFindSampleField(t *testing.T) {
s := NewFieldSampler(nil, FieldSamplerConfig{
FieldName: "field",
Rate: NewAtomicFieldSampleRate(1),
}).(*fieldSampler)
v, ok := s.findSampleField([]zapcore.Field{zap.String("field", "test")})
require.Equal(t, "test", v)
require.True(t, ok)
v, ok = s.findSampleField([]zapcore.Field{zap.Reflect("field", testStringLike("test"))})
require.Equal(t, "test", v)
require.True(t, ok)
v, ok = s.findSampleField([]zapcore.Field{zap.Stringer("field", testStringer("test"))})
require.Equal(t, "test", v)
require.True(t, ok)
_, ok = s.findSampleField([]zapcore.Field{zap.Int("field", 123)})
require.False(t, ok)
_, ok = s.findSampleField([]zapcore.Field{})
require.False(t, ok)
}