2019-06-24 04:51:39 -05:00
|
|
|
package remotecache
|
|
|
|
|
|
|
|
import (
|
2019-08-13 05:51:13 -05:00
|
|
|
"crypto/tls"
|
2019-06-24 04:51:39 -05:00
|
|
|
"fmt"
|
|
|
|
"testing"
|
|
|
|
|
|
|
|
"github.com/stretchr/testify/assert"
|
2019-08-13 05:51:13 -05:00
|
|
|
redis "gopkg.in/redis.v5"
|
2019-06-24 04:51:39 -05:00
|
|
|
)
|
|
|
|
|
|
|
|
func Test_parseRedisConnStr(t *testing.T) {
|
|
|
|
cases := map[string]struct {
|
|
|
|
InputConnStr string
|
|
|
|
OutputOptions *redis.Options
|
|
|
|
ShouldErr bool
|
|
|
|
}{
|
|
|
|
"all redis options should parse": {
|
2019-08-13 05:51:13 -05:00
|
|
|
"addr=127.0.0.1:6379,pool_size=100,db=1,password=grafanaRocks,ssl=false",
|
2019-06-24 04:51:39 -05:00
|
|
|
&redis.Options{
|
2019-08-13 05:51:13 -05:00
|
|
|
Addr: "127.0.0.1:6379",
|
|
|
|
PoolSize: 100,
|
|
|
|
DB: 1,
|
|
|
|
Password: "grafanaRocks",
|
|
|
|
Network: "tcp",
|
|
|
|
TLSConfig: nil,
|
2019-06-24 04:51:39 -05:00
|
|
|
},
|
|
|
|
false,
|
|
|
|
},
|
|
|
|
"subset of redis options should parse": {
|
|
|
|
"addr=127.0.0.1:6379,pool_size=100",
|
|
|
|
&redis.Options{
|
|
|
|
Addr: "127.0.0.1:6379",
|
|
|
|
PoolSize: 100,
|
|
|
|
Network: "tcp",
|
|
|
|
},
|
|
|
|
false,
|
|
|
|
},
|
2019-08-13 05:51:13 -05:00
|
|
|
"ssl set to true should result in default TLS configuration with tls set to addr's host": {
|
|
|
|
"addr=grafana.com:6379,ssl=true",
|
|
|
|
&redis.Options{
|
|
|
|
Addr: "grafana.com:6379",
|
|
|
|
Network: "tcp",
|
|
|
|
TLSConfig: &tls.Config{ServerName: "grafana.com"},
|
|
|
|
},
|
|
|
|
false,
|
|
|
|
},
|
|
|
|
"ssl to insecure should result in TLS configuration with InsecureSkipVerify": {
|
|
|
|
"addr=127.0.0.1:6379,ssl=insecure",
|
|
|
|
&redis.Options{
|
|
|
|
Addr: "127.0.0.1:6379",
|
|
|
|
Network: "tcp",
|
|
|
|
TLSConfig: &tls.Config{InsecureSkipVerify: true},
|
|
|
|
},
|
|
|
|
false,
|
|
|
|
},
|
|
|
|
"invalid SSL option should err": {
|
|
|
|
"addr=127.0.0.1:6379,ssl=dragons",
|
|
|
|
nil,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
"invalid pool_size value should err": {
|
|
|
|
"addr=127.0.0.1:6379,pool_size=seven",
|
|
|
|
nil,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
"invalid db value should err": {
|
|
|
|
"addr=127.0.0.1:6379,db=seven",
|
|
|
|
nil,
|
|
|
|
true,
|
|
|
|
},
|
2019-06-24 04:51:39 -05:00
|
|
|
"trailing comma should err": {
|
|
|
|
"addr=127.0.0.1:6379,pool_size=100,",
|
|
|
|
nil,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
"invalid key should err": {
|
|
|
|
"addr=127.0.0.1:6379,puddle_size=100",
|
|
|
|
nil,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
"empty connection string should err": {
|
|
|
|
"",
|
|
|
|
nil,
|
|
|
|
true,
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
for reason, testCase := range cases {
|
|
|
|
options, err := parseRedisConnStr(testCase.InputConnStr)
|
|
|
|
if testCase.ShouldErr {
|
|
|
|
assert.Error(t, err, fmt.Sprintf("error cases should return non-nil error for test case %v", reason))
|
|
|
|
assert.Nil(t, options, fmt.Sprintf("error cases should return nil for redis options for test case %v", reason))
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
assert.NoError(t, err, reason)
|
|
|
|
assert.EqualValues(t, testCase.OutputOptions, options, reason)
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|