mirror of
https://github.com/zeromicro/go-zero.git
synced 2025-01-26 11:28:46 +08:00
acdaee0fb6
* change to use ServiceGroup to make it more clear * fix golint issues in core/stat
43 lines
771 B
Go
43 lines
771 B
Go
package stat
|
|
|
|
import (
|
|
"strconv"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/tal-tech/go-zero/core/logx"
|
|
)
|
|
|
|
func TestMetrics(t *testing.T) {
|
|
logx.Disable()
|
|
DisableLog()
|
|
defer logEnabled.Set(true)
|
|
|
|
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)
|
|
}
|
|
}
|
|
|
|
type mockedWriter struct {
|
|
report *StatReport
|
|
}
|
|
|
|
func (m *mockedWriter) Write(report *StatReport) error {
|
|
m.report = report
|
|
return nil
|
|
}
|