* mw/kubernetes: resync to opts Only used to initialize the cache that already has a dnsControlopts, so remove it from the main kubernetes struct. * Fix test * mw/kubernetes: LabelSelector to options as well Labels select is also only used for init. Don't carry it in the main kubernetes struct. * remove this test: can't happen Caddyfile parser will only call setup when it sees kubernetes. * erge gone wrong
35 lines
971 B
Go
35 lines
971 B
Go
package kubernetes
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/mholt/caddy"
|
|
)
|
|
|
|
func TestKubernetesParseReverseZone(t *testing.T) {
|
|
tests := []struct {
|
|
input string // Corefile data as string
|
|
expectedZones []string // expected count of defined zones.
|
|
}{
|
|
{`kubernetes coredns.local 10.0.0.0/16`, []string{"coredns.local.", "0.10.in-addr.arpa."}},
|
|
{`kubernetes coredns.local 10.0.0.0/17`, []string{"coredns.local.", "10.0.0.0/17."}},
|
|
}
|
|
|
|
for i, tc := range tests {
|
|
c := caddy.NewTestController("dns", tc.input)
|
|
k, _, err := kubernetesParse(c)
|
|
if err != nil {
|
|
t.Fatalf("Test %d: Expected no error, got %q", i, err)
|
|
}
|
|
|
|
zl := len(k.Zones)
|
|
if zl != len(tc.expectedZones) {
|
|
t.Errorf("Test %d: Expected kubernetes to be initialized with %d zones, found %d zones", i, len(tc.expectedZones), zl)
|
|
}
|
|
for i, z := range tc.expectedZones {
|
|
if k.Zones[i] != z {
|
|
t.Errorf("Test %d: Expected zones to be %q, got %q", i, z, k.Zones[i])
|
|
}
|
|
}
|
|
}
|
|
}
|