-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathlogger_test.go
96 lines (84 loc) · 2.06 KB
/
logger_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
package signalr
import (
"context"
"encoding/json"
"io"
"os"
"sync"
"testing"
"time"
"github.com/go-kit/log"
)
type loggerConfig struct {
Enabled bool
Debug bool
}
var lConf loggerConfig
var tLog StructuredLogger
func testLoggerOption() func(Party) error {
testLogger()
return Logger(tLog, lConf.Debug)
}
func testLogger() StructuredLogger {
if tLog == nil {
lConf = loggerConfig{Enabled: false, Debug: false}
b, err := os.ReadFile("testLogConf.json")
if err == nil {
err = json.Unmarshal(b, &lConf)
if err != nil {
lConf = loggerConfig{Enabled: false, Debug: false}
}
}
writer := io.Discard
if lConf.Enabled {
writer = os.Stderr
}
tLog = log.NewLogfmtLogger(writer)
}
return tLog
}
type panicLogger struct {
log log.Logger
}
func (p *panicLogger) Log(keyVals ...interface{}) error {
_ = p.log.Log(keyVals...)
panic("panic as expected")
}
type testLogWriter struct {
mx sync.Mutex
p []byte
t *testing.T
}
func (t *testLogWriter) Write(p []byte) (n int, err error) {
t.mx.Lock()
defer t.mx.Unlock()
t.p = append(t.p, p...)
if len(p) > 0 && p[len(p)-1] == 10 { // Will not work on Windows, but doesn't matter. This is only to check if the logger output still looks as expected
t.t.Log(string(t.p))
t.p = nil
}
return len(p), nil
}
func Test_PanicLogger(t *testing.T) {
defer func() {
if err := recover(); err != nil {
t.Errorf("panic in logger: '%v'", err)
}
}()
ctx, cancel := context.WithCancel(context.Background())
server, _ := NewServer(ctx, SimpleHubFactory(&simpleHub{}),
Logger(&panicLogger{log: log.NewLogfmtLogger(&testLogWriter{t: t})}, true),
ChanReceiveTimeout(200*time.Millisecond),
StreamBufferCapacity(5))
// Create both ends of the connection
cliConn, srvConn := newClientServerConnections()
// Start the server
go func() { _ = server.Serve(srvConn) }()
// Create the Client
client, _ := NewClient(ctx, WithConnection(cliConn), Logger(&panicLogger{log: log.NewLogfmtLogger(&testLogWriter{t: t})}, true))
// Start it
client.Start()
// Do something
<-client.Send("InvokeMe")
cancel()
}