123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189 |
- package mon
- import (
- "context"
- "errors"
- "testing"
- "github.com/stretchr/testify/assert"
- "github.com/wuntsong-org/go-zero-plus/core/logx/logtest"
- "github.com/wuntsong-org/go-zero-plus/core/timex"
- )
- func TestFormatAddrs(t *testing.T) {
- tests := []struct {
- addrs []string
- expect string
- }{
- {
- addrs: []string{"a", "b"},
- expect: "a,b",
- },
- {
- addrs: []string{"a", "b", "c"},
- expect: "a,b,c",
- },
- {
- addrs: []string{},
- expect: "",
- },
- {
- addrs: nil,
- expect: "",
- },
- }
- for _, test := range tests {
- assert.Equal(t, test.expect, FormatAddr(test.addrs))
- }
- }
- func Test_logDuration(t *testing.T) {
- buf := logtest.NewCollector(t)
- buf.Reset()
- logDuration(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil)
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "slow")
- buf.Reset()
- logDuration(context.Background(), "foo", "bar", timex.Now(), nil)
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- buf.Reset()
- logDuration(context.Background(), "foo", "bar", timex.Now(), errors.New("bar"))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "fail")
- defer func() {
- logMon.Set(true)
- logSlowMon.Set(true)
- }()
- buf.Reset()
- DisableInfoLog()
- logDuration(context.Background(), "foo", "bar", timex.Now(), nil)
- assert.Empty(t, buf.String())
- buf.Reset()
- logDuration(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil)
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "slow")
- buf.Reset()
- DisableLog()
- logDuration(context.Background(), "foo", "bar", timex.Now(), nil)
- assert.Empty(t, buf.String())
- buf.Reset()
- logDuration(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil)
- assert.Empty(t, buf.String())
- buf.Reset()
- logDuration(context.Background(), "foo", "bar", timex.Now(), errors.New("bar"))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "fail")
- }
- func Test_logDurationWithDoc(t *testing.T) {
- buf := logtest.NewCollector(t)
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil, make(chan int))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "slow")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil, "{'json': ''}")
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "slow")
- assert.Contains(t, buf.String(), "json")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), nil, make(chan int))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), nil, "{'json': ''}")
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "json")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), errors.New("bar"), make(chan int))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "fail")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), errors.New("bar"), "{'json': ''}")
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "fail")
- assert.Contains(t, buf.String(), "json")
- defer func() {
- logMon.Set(true)
- logSlowMon.Set(true)
- }()
- buf.Reset()
- DisableInfoLog()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), nil, make(chan int))
- assert.Empty(t, buf.String())
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), nil, "{'json': ''}")
- assert.Empty(t, buf.String())
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil, make(chan int))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "slow")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil, "{'json': ''}")
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "slow")
- assert.Contains(t, buf.String(), "json")
- buf.Reset()
- DisableLog()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), nil, make(chan int))
- assert.Empty(t, buf.String())
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), nil, "{'json': ''}")
- assert.Empty(t, buf.String())
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil, make(chan int))
- assert.Empty(t, buf.String())
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now()-slowThreshold.Load()*2, nil, "{'json': ''}")
- assert.Empty(t, buf.String())
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), errors.New("bar"), make(chan int))
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "fail")
- buf.Reset()
- logDurationWithDocs(context.Background(), "foo", "bar", timex.Now(), errors.New("bar"), "{'json': ''}")
- assert.Contains(t, buf.String(), "foo")
- assert.Contains(t, buf.String(), "bar")
- assert.Contains(t, buf.String(), "fail")
- assert.Contains(t, buf.String(), "json")
- }
|