dave/app/config_test.go

127 lines
2.5 KiB
Go
Raw Normal View History

2018-05-22 22:08:14 +02:00
package app
import (
2018-05-24 21:37:42 +02:00
"bytes"
"encoding/json"
"io/ioutil"
"os"
"path/filepath"
2018-05-22 22:08:14 +02:00
"reflect"
2018-05-24 21:37:42 +02:00
"strconv"
2018-05-22 22:08:14 +02:00
"testing"
2018-05-24 21:37:42 +02:00
"time"
2018-05-22 22:08:14 +02:00
"github.com/spf13/viper"
)
func TestParseConfig(t *testing.T) {
viper.Reset()
tmpDir := filepath.Join(os.TempDir(), "dave__"+strconv.FormatInt(time.Now().UnixNano(), 10))
os.Mkdir(tmpDir, 0700)
defer os.RemoveAll(tmpDir)
tests := []struct {
name string
want *Config
}{
2018-05-24 21:37:42 +02:00
{"default", cfg(t, tmpDir)},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
if got := ParseConfig(); !reflect.DeepEqual(got, tt.want) {
gotJSON, _ := json.Marshal(got)
wantJSON, _ := json.Marshal(tt.want)
t.Errorf("ParseConfig() = %s, want %s", gotJSON, wantJSON)
}
})
}
}
func cfg(t *testing.T, tmpDir string) *Config {
viper.SetConfigType("yaml")
var yamlCfg = []byte(`
2018-05-22 22:08:14 +02:00
address: 1.2.3.4
port: 42
prefix: /oh-de-lally
tls:
2018-05-24 21:37:42 +02:00
keyFile: ` + tmpDir + `/robin.pem
certFile: ` + tmpDir + `/tuck.pem
2018-05-22 22:08:14 +02:00
dir: /sherwood/forest
realm: uk
users:
lj:
password: 123
subdir: /littlejohn
srf:
password: 234
subdir: /sheriff
log:
error: true
2018-05-24 21:37:42 +02:00
`)
2018-05-22 22:08:14 +02:00
err := ioutil.WriteFile(filepath.Join(tmpDir, "config.yaml"), yamlCfg, 0600)
if err != nil {
t.Errorf("error writing test config. error = %v", err)
}
err = viper.ReadConfig(bytes.NewBuffer(yamlCfg))
if err != nil {
t.Errorf("error reading test config. error = %v", err)
}
var cfg = &Config{}
viper.Unmarshal(&cfg)
// let viper read from the tmp directory fist
viper.AddConfigPath(tmpDir)
// add dummy cert and key file
_, err = os.OpenFile(filepath.Join(tmpDir, "robin.pem"), os.O_RDWR|os.O_CREATE, 0644)
if err != nil {
t.Errorf("error creating key file. error = %v", err)
return nil
}
_, err = os.OpenFile(filepath.Join(tmpDir, "tuck.pem"), os.O_RDWR|os.O_CREATE, 0644)
if err != nil {
t.Errorf("error creating cert file. error = %v", err)
return nil
}
viper.AddConfigPath(tmpDir)
return cfg
}
func TestSetDefaults(t *testing.T) {
viper.Reset()
tests := []struct {
name string
value interface{}
}{
{"Address", "127.0.0.1"},
{"Port", "8000"},
{"Prefix", ""},
{"Dir", "/tmp"},
{"TLS", nil},
{"Realm", "dave"},
{"Log.Error", true},
{"Log.Create", false},
{"Log.Read", false},
{"Log.Update", false},
{"Log.Delete", false},
}
for _, tt := range tests {
t.Run(tt.name, func(t *testing.T) {
viper.Reset()
setDefaults()
if viper.Get(tt.name) != tt.value {
t.Errorf("Default Keys doesn't fit. name = %v, want = %v", tt.name, tt.value)
}
})
}
}