* Extend bind to allow multiple addresses. UTs added. Changes the log for server starting, adding address when available * update readme for bind * fixes after review * minor fix on readme * accept multiple BIND directives in blocserver, consolidate the addresses * fixes after review - format logging server address, variable names
46 lines
1.2 KiB
Go
46 lines
1.2 KiB
Go
package bind
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/coredns/coredns/core/dnsserver"
|
|
|
|
"github.com/mholt/caddy"
|
|
)
|
|
|
|
func TestSetupBind(t *testing.T) {
|
|
for i, test := range []struct {
|
|
config string
|
|
expected []string
|
|
failing bool
|
|
}{
|
|
{`bind 1.2.3.4`, []string{"1.2.3.4"}, false},
|
|
{`bind`, nil, true},
|
|
{`bind 1.2.3.invalid`, nil, true},
|
|
{`bind 1.2.3.4 ::5`, []string{"1.2.3.4", "::5"}, false},
|
|
{`bind ::1 1.2.3.4 ::5 127.9.9.0`, []string{"::1", "1.2.3.4", "::5", "127.9.9.0"}, false},
|
|
{`bind ::1 1.2.3.4 ::5 127.9.9.0 noone`, nil, true},
|
|
} {
|
|
c := caddy.NewTestController("dns", test.config)
|
|
err := setupBind(c)
|
|
if err != nil {
|
|
if !test.failing {
|
|
t.Fatalf("test %d, expected no errors, but got: %v", i, err)
|
|
}
|
|
continue
|
|
}
|
|
if test.failing {
|
|
t.Fatalf("test %d, expected to failed but did not, returned values", i)
|
|
}
|
|
cfg := dnsserver.GetConfig(c)
|
|
if len(cfg.ListenHosts) != len(test.expected) {
|
|
t.Errorf("test %d : expected the config's ListenHosts size to be %d, was %d", i, len(test.expected), len(cfg.ListenHosts))
|
|
continue
|
|
}
|
|
for i, v := range test.expected {
|
|
if got, want := cfg.ListenHosts[i], v; got != want {
|
|
t.Errorf("test %d : expected the config's ListenHost to be %s, was %s", i, want, got)
|
|
}
|
|
}
|
|
}
|
|
}
|