go-zero/core/stat/metrics_test.go

77 lines
1.5 KiB
Go
Raw Normal View History

2020-10-07 23:15:34 +08:00
package stat
import (
2024-02-23 23:00:35 +08:00
"errors"
2020-10-07 23:15:34 +08:00
"strconv"
"testing"
"time"
"github.com/stretchr/testify/assert"
2024-02-23 23:00:35 +08:00
"github.com/zeromicro/go-zero/core/logx/logtest"
2020-10-07 23:15:34 +08:00
)
func TestMetrics(t *testing.T) {
DisableLog()
defer logEnabled.Set(true)
2020-10-07 23:15:34 +08:00
counts := []int{1, 5, 10, 100, 1000, 1000}
for _, count := range counts {
m := NewMetrics("foo")
m.SetName("bar")
for i := 0; i < count; i++ {
m.Add(Task{
Duration: time.Millisecond * time.Duration(i),
Description: strconv.Itoa(i),
})
}
m.AddDrop()
var writer mockedWriter
SetReportWriter(&writer)
m.executor.Flush()
assert.Equal(t, "bar", writer.report.Name)
}
}
2024-02-23 23:00:35 +08:00
func TestTopDurationWithEmpty(t *testing.T) {
assert.Equal(t, float32(0), getTopDuration(nil))
assert.Equal(t, float32(0), getTopDuration([]Task{}))
}
func TestLogAndReport(t *testing.T) {
buf := logtest.NewCollector(t)
old := logEnabled.True()
logEnabled.Set(true)
t.Cleanup(func() {
logEnabled.Set(old)
})
log(&StatReport{})
assert.NotEmpty(t, buf.String())
writerLock.Lock()
writer := reportWriter
writerLock.Unlock()
buf = logtest.NewCollector(t)
t.Cleanup(func() {
SetReportWriter(writer)
})
SetReportWriter(&badWriter{})
writeReport(&StatReport{})
assert.NotEmpty(t, buf.String())
}
2020-10-07 23:15:34 +08:00
type mockedWriter struct {
report *StatReport
}
func (m *mockedWriter) Write(report *StatReport) error {
m.report = report
return nil
}
2024-02-23 23:00:35 +08:00
type badWriter struct{}
2024-03-08 22:35:17 +08:00
func (b *badWriter) Write(_ *StatReport) error {
2024-02-23 23:00:35 +08:00
return errors.New("bad")
}