mirror of
https://github.com/nshttpd/mikrotik-exporter.git
synced 2025-01-23 21:01:50 +01:00
65 lines
1.5 KiB
Go
65 lines
1.5 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))
|
|
}
|
|
|
|
assertDevice("test1", "192.168.1.1", "foo", "bar", c.Devices[0], t)
|
|
assertDevice("test2", "192.168.2.1", "test", "123", c.Devices[1], t)
|
|
assertFeature("BGP", c.Features.BGP, t)
|
|
assertFeature("DHCP", c.Features.DHCP, t)
|
|
assertFeature("DHCPv6", c.Features.DHCPv6, t)
|
|
assertFeature("Pools", c.Features.Pools, t)
|
|
assertFeature("Routes", c.Features.Routes, t)
|
|
assertFeature("Optics", c.Features.Optics, t)
|
|
assertFeature("WlanSTA", c.Features.WlanSTA, t)
|
|
assertFeature("WlanIF", c.Features.WlanIF, t)
|
|
assertFeature("Ipsec", c.Features.Ipsec, 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 assertDevice(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)
|
|
}
|
|
}
|
|
|
|
func assertFeature(name string, v bool, t *testing.T) {
|
|
if !v {
|
|
t.Fatalf("exprected feature %s to be enabled", name)
|
|
}
|
|
}
|