mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 23:05:28 +00:00
233eacf0a4
* inject logger and create logdrop sink * init sink with an empty struct instead of nil * wrap a logger instead of a sink and add a discard logger to avoid double logging * fix compile errors * fix linter errors * Fix bug where log arguments aren't properly formatted * Move log sink construction outside of handler * Add prometheus definition and docs for log drop counter Co-authored-by: Daniel Upton <daniel@floppy.co>
54 lines
1.3 KiB
Go
54 lines
1.3 KiB
Go
package logdrop
|
|
|
|
import (
|
|
"context"
|
|
"testing"
|
|
"time"
|
|
|
|
"github.com/hashicorp/go-hclog"
|
|
"github.com/stretchr/testify/mock"
|
|
"github.com/stretchr/testify/require"
|
|
|
|
"github.com/hashicorp/consul/sdk/testutil/retry"
|
|
)
|
|
|
|
func TestNewLogDrop(t *testing.T) {
|
|
mockLogger := NewMockLogger(t)
|
|
mockLogger.On("Log", hclog.Info, "hello", "test", 0).Return()
|
|
ld := NewLogDropSink(context.Background(), 10, mockLogger, func(_ Log) {})
|
|
require.NotNil(t, ld)
|
|
ld.Accept("test Log", hclog.Info, "hello", "test", 0)
|
|
retry.Run(t, func(r *retry.R) {
|
|
mockLogger.AssertNumberOfCalls(r, "Log", 1)
|
|
})
|
|
|
|
}
|
|
|
|
func TestLogDroppedWhenChannelFilled(t *testing.T) {
|
|
mockLogger := NewMockLogger(t)
|
|
ctx, cancelFunc := context.WithCancel(context.Background())
|
|
defer cancelFunc()
|
|
block := make(chan interface{})
|
|
mockLogger.On("Log", hclog.Debug, "hello").Run(func(args mock.Arguments) {
|
|
<-block
|
|
})
|
|
|
|
var called = make(chan interface{})
|
|
ld := NewLogDropSink(ctx, 1, mockLogger, func(l Log) {
|
|
close(called)
|
|
})
|
|
for i := 0; i < 2; i++ {
|
|
ld.Accept("test", hclog.Debug, "hello")
|
|
}
|
|
|
|
select {
|
|
case <-called:
|
|
close(block)
|
|
case <-time.After(100 * time.Millisecond):
|
|
t.Fatal("timeout waiting for drop func to be called")
|
|
}
|
|
retry.Run(t, func(r *retry.R) {
|
|
mockLogger.AssertNumberOfCalls(r, "Log", 1)
|
|
})
|
|
}
|