* added config file implementation, refactoring * add gitignore * improved test * preperations for more metrics * added resource metrics * added first bgp metrics * added asn as label for bgp metrics * added prefix and message counts to bgp metrics * simplified * Update README.md * added yaml dependency * fixed go routine call * added timeout * clean up * added TLS support * set default api port for TLS * added routes metric * added missing log information
50 lines
1.1 KiB
Go
50 lines
1.1 KiB
Go
package config
|
|
|
|
import (
|
|
"bytes"
|
|
"io/ioutil"
|
|
"testing"
|
|
)
|
|
|
|
func TestShouldParse(t *testing.T) {
|
|
b := loadTestFile(t)
|
|
c, err := Load(bytes.NewReader(b))
|
|
if err != nil {
|
|
t.Fatalf("could not parse: %v", err)
|
|
}
|
|
|
|
if len(c.Devices) != 2 {
|
|
t.Fatalf("expected 2 devices, got %v", len(c.Devices))
|
|
}
|
|
|
|
assertConfig("test1", "192.168.1.1", "foo", "bar", c.Devices[0], t)
|
|
assertConfig("test2", "192.168.2.1", "test", "123", c.Devices[1], t)
|
|
}
|
|
|
|
func loadTestFile(t *testing.T) []byte {
|
|
b, err := ioutil.ReadFile("test/config.test.yml")
|
|
if err != nil {
|
|
t.Fatalf("could not load config: %v", err)
|
|
}
|
|
|
|
return b
|
|
}
|
|
|
|
func assertConfig(name, address, user, password string, c Device, t *testing.T) {
|
|
if c.Name != name {
|
|
t.Fatalf("expected name %s, got %s", name, c.Name)
|
|
}
|
|
|
|
if c.Address != address {
|
|
t.Fatalf("expected address %s, got %s", address, c.Address)
|
|
}
|
|
|
|
if c.User != user {
|
|
t.Fatalf("expected user %s, got %s", user, c.User)
|
|
}
|
|
|
|
if c.Password != password {
|
|
t.Fatalf("expected password %s, got %s", password, c.Password)
|
|
}
|
|
}
|