2021-08-19 13:31:12 +00:00
|
|
|
package openvpn
|
2021-01-26 04:17:22 +00:00
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func Test_processLogLine(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
tests := map[string]struct {
|
|
|
|
|
s string
|
|
|
|
|
filtered string
|
2021-09-23 17:05:48 +00:00
|
|
|
level logLevel
|
2021-01-26 04:17:22 +00:00
|
|
|
}{
|
2021-09-23 17:05:48 +00:00
|
|
|
"empty string": {"", "", levelInfo},
|
|
|
|
|
"random string": {"asdasqdb", "asdasqdb", levelInfo},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn unknown": {
|
|
|
|
|
"message",
|
|
|
|
|
"message",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelInfo},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn note": {
|
|
|
|
|
"NOTE: message",
|
|
|
|
|
"message",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelInfo},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn warning": {
|
|
|
|
|
"WARNING: message",
|
|
|
|
|
"message",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelWarn},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn options error": {
|
|
|
|
|
"Options error: message",
|
|
|
|
|
"message",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelError},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn ignored message": {
|
|
|
|
|
"NOTE: UID/GID downgrade will be delayed because of --client, --pull, or --up-delay",
|
|
|
|
|
"",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelInfo},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn success": {
|
|
|
|
|
"Initialization Sequence Completed",
|
|
|
|
|
"Initialization Sequence Completed",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelInfo},
|
2021-01-26 04:17:22 +00:00
|
|
|
"openvpn auth failed": {
|
|
|
|
|
"AUTH: Received control message: AUTH_FAILED",
|
2021-07-16 00:49:50 +00:00
|
|
|
"AUTH: Received control message: AUTH_FAILED\n\nYour credentials might be wrong 🤨\n\n",
|
2021-09-23 17:05:48 +00:00
|
|
|
levelError},
|
2021-01-26 04:17:22 +00:00
|
|
|
}
|
|
|
|
|
for name, tc := range tests {
|
|
|
|
|
tc := tc
|
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
filtered, level := processLogLine(tc.s)
|
|
|
|
|
assert.Equal(t, tc.filtered, filtered)
|
|
|
|
|
assert.Equal(t, tc.level, level)
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|