2015-09-01 03:17:13 +00:00
|
|
|
package monitor_test
|
|
|
|
|
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/BurntSushi/toml"
|
2016-02-10 17:26:18 +00:00
|
|
|
"github.com/influxdata/influxdb/monitor"
|
2015-09-01 03:17:13 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestConfig_Parse(t *testing.T) {
|
|
|
|
// Parse configuration.
|
|
|
|
var c monitor.Config
|
|
|
|
if _, err := toml.Decode(`
|
|
|
|
store-enabled=true
|
|
|
|
store-database="the_db"
|
|
|
|
store-interval="10m"
|
|
|
|
`, &c); err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Validate configuration.
|
|
|
|
if !c.StoreEnabled {
|
2015-09-01 21:57:15 +00:00
|
|
|
t.Fatalf("unexpected store-enabled: %v", c.StoreEnabled)
|
2015-09-01 03:17:13 +00:00
|
|
|
} else if c.StoreDatabase != "the_db" {
|
|
|
|
t.Fatalf("unexpected store-database: %s", c.StoreDatabase)
|
|
|
|
} else if time.Duration(c.StoreInterval) != 10*time.Minute {
|
|
|
|
t.Fatalf("unexpected store-interval: %s", c.StoreInterval)
|
|
|
|
}
|
|
|
|
}
|
2017-01-03 23:21:25 +00:00
|
|
|
|
|
|
|
func TestConfig_Validate(t *testing.T) {
|
|
|
|
// NewConfig must validate correctly.
|
|
|
|
c := monitor.NewConfig()
|
|
|
|
if err := c.Validate(); err != nil {
|
|
|
|
t.Fatalf("unexpected validation error: %s", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Non-positive duration is invalid.
|
|
|
|
c = monitor.NewConfig()
|
|
|
|
c.StoreInterval *= 0
|
|
|
|
if err := c.Validate(); err == nil {
|
|
|
|
t.Fatalf("unexpected successful validation for %#v", c)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Empty database is invalid.
|
|
|
|
c = monitor.NewConfig()
|
|
|
|
c.StoreDatabase = ""
|
|
|
|
if err := c.Validate(); err == nil {
|
|
|
|
t.Fatalf("unexpected successful validation for %#v", c)
|
|
|
|
}
|
|
|
|
}
|