-
Notifications
You must be signed in to change notification settings - Fork 76
/
Copy pathparselog_test.go
105 lines (96 loc) · 2.62 KB
/
parselog_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
97
98
99
100
101
102
103
104
105
package ovpm
import (
"bytes"
"io"
"reflect"
"testing"
"github.com/stretchr/testify/assert"
)
func Test_parseStatusLog(t *testing.T) {
const exampleLogFile = `OpenVPN CLIENT LIST
Updated,Mon Mar 26 13:26:10 2018
Common Name,Real Address,Bytes Received,Bytes Sent,Connected Since
google.DNS,8.8.8.8:53246,527914279,3204562859,Sat Mar 17 16:26:38 2018
google1.DNS,8.8.4.4:33974,42727443,291595456,Mon Mar 26 08:24:08 2018
ROUTING TABLE
Virtual Address,Common Name,Real Address,Last Ref
10.20.30.6,google.DNS,8.8.8.8:33974,Mon Mar 26 13:26:04 2018
10.20.30.5,google1.DNS,8.8.4.4:53246,Mon Mar 26 13:25:57 2018
GLOBAL STATS
Max bcast/mcast queue length,4
END
`
// Mock the status log file.
f := bytes.NewBufferString(exampleLogFile)
type args struct {
f io.Reader
}
tests := []struct {
name string
args args
want []clEntry
want1 []rtEntry
}{
{
"google", args{f},
[]clEntry{
clEntry{
CommonName: "google.DNS",
RealAddress: "8.8.8.8:53246",
BytesReceived: 527914279,
BytesSent: 3204562859,
ConnectedSince: stodt("Sat Mar 17 16:26:38 2018"),
},
clEntry{
CommonName: "google1.DNS",
RealAddress: "8.8.4.4:33974",
BytesReceived: 42727443,
BytesSent: 291595456,
ConnectedSince: stodt("Mon Mar 26 08:24:08 2018"),
},
},
[]rtEntry{
rtEntry{
VirtualAddress: "10.20.30.6",
CommonName: "google.DNS",
RealAddress: "8.8.8.8:33974",
LastRef: stodt("Mon Mar 26 13:26:04 2018"),
},
rtEntry{
VirtualAddress: "10.20.30.5",
CommonName: "google1.DNS",
RealAddress: "8.8.4.4:53246",
LastRef: stodt("Mon Mar 26 13:25:57 2018"),
},
},
},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
got, got1 := parseStatusLog(tt.args.f)
if !reflect.DeepEqual(got, tt.want) {
t.Errorf("parseStatusLog() got = %v, want %v", got, tt.want)
}
if !reflect.DeepEqual(got1, tt.want1) {
t.Errorf("parseStatusLog() got1 = %v, want %v", got1, tt.want1)
}
})
}
}
func Test_parseStatusLog_CorruptStatusLog(t *testing.T) {
const exampleLogFile = `OpenVPN CLIENT LIST
Updated,Mon Mar 26 13:26:10 2018
Common Name,Real Address,Bytes Received,Bytes Sent,Connected Since
google.DNS,8.8.8.8Name,Real Addressdfs,Last Ref
10.20.30.6,google.DNS,8.8.8.8:33974,Mon Mar 26 13:26:04 2018
10.20.30.5,google1.DNS,8..4.4:53246,Mon Mar 26 13:25:57 2018
GLOBAL STATS
Max bcast/mcast queue length,4
END
`
// Mock the status log file.
f := bytes.NewBufferString(exampleLogFile)
cl, rt := parseStatusLog(f)
assert.Empty(t, cl)
assert.Empty(t, rt)
}