123456789101112131415161718192021222324252627282930313233343536373839404142 |
- package stat
- import (
- "strconv"
- "testing"
- "time"
- "git.i2edu.net/i2/go-zero/core/logx"
- "github.com/stretchr/testify/assert"
- )
- 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
- }
|