Issue #162: Add tests for informer Configs
License: MIT Signed-off-by: Hector Sanjuan <hector@protocol.ai>
This commit is contained in:
parent
3cf4d90536
commit
89364fd671
78
informer/disk/config_test.go
Normal file
78
informer/disk/config_test.go
Normal file
|
@ -0,0 +1,78 @@
|
||||||
|
package disk
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
var cfgJSON = []byte(`
|
||||||
|
{
|
||||||
|
"metric_ttl": "1s",
|
||||||
|
"metric_type": "freespace"
|
||||||
|
}
|
||||||
|
`)
|
||||||
|
|
||||||
|
func TestLoadJSON(t *testing.T) {
|
||||||
|
cfg := &Config{}
|
||||||
|
err := cfg.LoadJSON(cfgJSON)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
j := &jsonConfig{}
|
||||||
|
|
||||||
|
json.Unmarshal(cfgJSON, j)
|
||||||
|
j.MetricTTL = "-10"
|
||||||
|
tst, _ := json.Marshal(j)
|
||||||
|
err = cfg.LoadJSON(tst)
|
||||||
|
if err == nil {
|
||||||
|
t.Error("expected error decoding metric_ttl")
|
||||||
|
}
|
||||||
|
|
||||||
|
j = &jsonConfig{}
|
||||||
|
json.Unmarshal(cfgJSON, j)
|
||||||
|
j.Type = "abc"
|
||||||
|
tst, _ = json.Marshal(j)
|
||||||
|
err = cfg.LoadJSON(tst)
|
||||||
|
if err == nil {
|
||||||
|
t.Error("expected error decoding check_interval")
|
||||||
|
}
|
||||||
|
|
||||||
|
j = &jsonConfig{}
|
||||||
|
json.Unmarshal(cfgJSON, j)
|
||||||
|
j.Type = "reposize"
|
||||||
|
tst, _ = json.Marshal(j)
|
||||||
|
err = cfg.LoadJSON(tst)
|
||||||
|
if err != nil {
|
||||||
|
t.Error("reposize should be a valid type")
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestToJSON(t *testing.T) {
|
||||||
|
cfg := &Config{}
|
||||||
|
cfg.LoadJSON(cfgJSON)
|
||||||
|
_, err := cfg.ToJSON()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDefault(t *testing.T) {
|
||||||
|
cfg := &Config{}
|
||||||
|
cfg.Default()
|
||||||
|
if cfg.Validate() != nil {
|
||||||
|
t.Fatal("error validating")
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg.MetricTTL = 0
|
||||||
|
if cfg.Validate() == nil {
|
||||||
|
t.Fatal("expected error validating")
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg.Default()
|
||||||
|
cfg.Type = MetricRepoSize
|
||||||
|
if cfg.Validate() != nil {
|
||||||
|
t.Fatal("MetricRepoSize is a valid type")
|
||||||
|
}
|
||||||
|
}
|
52
informer/numpin/config_test.go
Normal file
52
informer/numpin/config_test.go
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
package numpin
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
var cfgJSON = []byte(`
|
||||||
|
{
|
||||||
|
"metric_ttl": "1s"
|
||||||
|
}
|
||||||
|
`)
|
||||||
|
|
||||||
|
func TestLoadJSON(t *testing.T) {
|
||||||
|
cfg := &Config{}
|
||||||
|
err := cfg.LoadJSON(cfgJSON)
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
j := &jsonConfig{}
|
||||||
|
|
||||||
|
json.Unmarshal(cfgJSON, j)
|
||||||
|
j.MetricTTL = "-10"
|
||||||
|
tst, _ := json.Marshal(j)
|
||||||
|
err = cfg.LoadJSON(tst)
|
||||||
|
if err == nil {
|
||||||
|
t.Error("expected error decoding metric_ttl")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestToJSON(t *testing.T) {
|
||||||
|
cfg := &Config{}
|
||||||
|
cfg.LoadJSON(cfgJSON)
|
||||||
|
_, err := cfg.ToJSON()
|
||||||
|
if err != nil {
|
||||||
|
t.Fatal(err)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestDefault(t *testing.T) {
|
||||||
|
cfg := &Config{}
|
||||||
|
cfg.Default()
|
||||||
|
if cfg.Validate() != nil {
|
||||||
|
t.Fatal("error validating")
|
||||||
|
}
|
||||||
|
|
||||||
|
cfg.MetricTTL = 0
|
||||||
|
if cfg.Validate() == nil {
|
||||||
|
t.Fatal("expected error validating")
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user