coredns/plugin/normalize_test.go
Miek Gieben fcd0342e42 CIDR query routing (#1159)
* core: allow all CIDR ranges in zone specifications

Allow (e.g.) a v4 reverse on a /17. If a zone is specified in such a
way a FilterFunc is set in the config. This filter is checked against
incoming queries.

For all other queries this adds a 'x != nil' check which will not impact
performace too much. Benchmark function is added as well to check for
this as wel.

Add multiple tests in tests/server_reverse_test.go.

Benchmark shows in the non-reverse case this hardly impact the speed:

~~~
classless:
pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1431 ns/op	      16 B/op	       1 allocs/op

pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1429 ns/op	      16 B/op	       1 allocs/op

master:
pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1412 ns/op	      16 B/op	       1 allocs/op

pkg: github.com/coredns/coredns/core/dnsserver
BenchmarkCoreServeDNS-4   	 1000000	      1429 ns/op	      16 B/op	       1 allocs/op
~~~

* README.md updates
2017-10-24 10:16:03 +01:00

112 lines
2.6 KiB
Go

package plugin
import "testing"
func TestZoneMatches(t *testing.T) {
child := "example.org."
zones := Zones([]string{"org.", "."})
actual := zones.Matches(child)
if actual != "org." {
t.Errorf("Expected %v, got %v", "org.", actual)
}
child = "bla.example.org."
zones = Zones([]string{"bla.example.org.", "org.", "."})
actual = zones.Matches(child)
if actual != "bla.example.org." {
t.Errorf("Expected %v, got %v", "org.", actual)
}
}
func TestZoneNormalize(t *testing.T) {
zones := Zones([]string{"example.org", "Example.ORG.", "example.org."})
expected := "example.org."
zones.Normalize()
for _, actual := range zones {
if actual != expected {
t.Errorf("Expected %v, got %v\n", expected, actual)
}
}
}
func TestNameMatches(t *testing.T) {
matches := []struct {
child string
parent string
expected bool
}{
{".", ".", true},
{"example.org.", ".", true},
{"example.org.", "example.org.", true},
{"example.org.", "org.", true},
{"org.", "example.org.", false},
}
for _, m := range matches {
actual := Name(m.parent).Matches(m.child)
if actual != m.expected {
t.Errorf("Expected %v for %s/%s, got %v", m.expected, m.parent, m.child, actual)
}
}
}
func TestNameNormalize(t *testing.T) {
names := []string{
"example.org", "example.org.",
"Example.ORG.", "example.org."}
for i := 0; i < len(names); i += 2 {
ts := names[i]
expected := names[i+1]
actual := Name(ts).Normalize()
if expected != actual {
t.Errorf("Expected %v, got %v\n", expected, actual)
}
}
}
func TestHostNormalize(t *testing.T) {
hosts := []string{".:53", ".", "example.org:53", "example.org.", "example.org.:53", "example.org.",
"10.0.0.0/8:53", "10.in-addr.arpa.", "10.0.0.0/9", "10.in-addr.arpa.",
"dns://example.org", "example.org."}
for i := 0; i < len(hosts); i += 2 {
ts := hosts[i]
expected := hosts[i+1]
actual := Host(ts).Normalize()
if expected != actual {
t.Errorf("Expected %v, got %v\n", expected, actual)
}
}
}
func TestSplitHostPortReverse(t *testing.T) {
tests := map[string]int{
"example.org.": 0,
"10.0.0.0/9": 32 - 9,
"10.0.0.0/8": 32 - 8,
"10.0.0.0/17": 32 - 17,
"10.0.0.0/0": 32 - 0,
"10.0.0.0/64": 0,
"10.0.0.0": 0,
"10.0.0": 0,
"2003::1/65": 128 - 65,
}
for in, expect := range tests {
_, _, n, err := SplitHostPort(in)
if err != nil {
t.Errorf("Expected no error, got %q for %s", in, err)
}
if n == nil {
continue
}
ones, bits := n.Mask.Size()
got := bits - ones
if got != expect {
t.Errorf("Expected %d, got %d for %s", expect, got, in)
}
}
}