-
Notifications
You must be signed in to change notification settings - Fork 0
/
logLine_test.go
41 lines (32 loc) · 1.04 KB
/
logLine_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
package logger_test
import (
"fmt"
"testing"
"github.com/Reshusk23/sr-me-core/marshal"
logger "github.com/Reshusk23/sr-me-logger"
"github.com/Reshusk23/sr-me-logger/proto"
"github.com/stretchr/testify/assert"
)
func TestLogLineWrapper_MarshalUnmarshalShouldWork(t *testing.T) {
llw := generateLogLineWrapper()
testMarshalUnmarshal(t, "gogo protobuf", &marshal.GogoProtoMarshalizer{}, llw)
}
func generateLogLineWrapper() logger.LogLineWrapper {
return logger.LogLineWrapper{
LogLineMessage: proto.LogLineMessage{
Message: "test message",
LogLevel: 4,
Args: []string{"arg1", "arg2", "arg3", "arg4"},
Timestamp: 11223344,
},
}
}
func testMarshalUnmarshal(t *testing.T, marshName string, marsh logger.Marshalizer, llw logger.LogLineWrapper) {
llwCopyForAssert := llw
buff, err := marsh.Marshal(&llw)
assert.Nil(t, err)
llwRecovered := &logger.LogLineWrapper{}
err = marsh.Unmarshal(llwRecovered, buff)
assert.Nil(t, err)
assert.Equal(t, &llwCopyForAssert, llwRecovered, fmt.Sprintf("for marshalizer %v", marshName))
}