coredns/plugin/cache/minttl_test.go
Miek Gieben 68b45f5377
plugin/cache: unroll minTTL loop (#1773)
This allocates memory because of the append, just unroll the loop.
Also add benchmark.

Before:
goos: linux
goarch: amd64
pkg: github.com/coredns/coredns/plugin/cache
BenchmarkCacheResponse-4   	  100000	     11910 ns/op
BenchmarkMinMsgTTL-4       	 1000000	      1494 ns/op
PASS

After:
goos: linux
goarch: amd64
pkg: github.com/coredns/coredns/plugin/cache
BenchmarkCacheResponse-4   	  100000	     12016 ns/op
BenchmarkMinMsgTTL-4       	 2000000	       668 ns/op
PASS
2018-05-08 18:36:29 +01:00

72 lines
2 KiB
Go

package cache
import (
"testing"
"time"
"github.com/coredns/coredns/plugin/pkg/response"
"github.com/coredns/coredns/plugin/test"
"github.com/miekg/dns"
)
// See https://github.com/kubernetes/dns/issues/121, add some specific tests for those use cases.
func TestMinMsgTTL(t *testing.T) {
m := new(dns.Msg)
m.SetQuestion("z.alm.im.", dns.TypeA)
m.Ns = []dns.RR{
test.SOA("alm.im. 1800 IN SOA ivan.ns.cloudflare.com. dns.cloudflare.com. 2025042470 10000 2400 604800 3600"),
}
utc := time.Now().UTC()
mt, _ := response.Typify(m, utc)
if mt != response.NoData {
t.Fatalf("Expected type to be response.NoData, got %s", mt)
}
dur := minMsgTTL(m, mt) // minTTL on msg is 3600 (neg. ttl on SOA)
if dur != time.Duration(3600*time.Second) {
t.Fatalf("Expected minttl duration to be %d, got %d", 3600, dur)
}
m.Rcode = dns.RcodeNameError
mt, _ = response.Typify(m, utc)
if mt != response.NameError {
t.Fatalf("Expected type to be response.NameError, got %s", mt)
}
dur = minMsgTTL(m, mt) // minTTL on msg is 3600 (neg. ttl on SOA)
if dur != time.Duration(3600*time.Second) {
t.Fatalf("Expected minttl duration to be %d, got %d", 3600, dur)
}
}
func BenchmarkMinMsgTTL(b *testing.B) {
m := new(dns.Msg)
m.SetQuestion("example.org.", dns.TypeA)
m.Ns = []dns.RR{
test.A("a.example.org. 1800 IN A 127.0.0.53"),
test.A("b.example.org. 1900 IN A 127.0.0.53"),
test.A("c.example.org. 1600 IN A 127.0.0.53"),
test.A("d.example.org. 1100 IN A 127.0.0.53"),
test.A("e.example.org. 1000 IN A 127.0.0.53"),
}
m.Extra = []dns.RR{
test.A("a.example.org. 1800 IN A 127.0.0.53"),
test.A("b.example.org. 1600 IN A 127.0.0.53"),
test.A("c.example.org. 1400 IN A 127.0.0.53"),
test.A("d.example.org. 1200 IN A 127.0.0.53"),
test.A("e.example.org. 1100 IN A 127.0.0.53"),
}
utc := time.Now().UTC()
mt, _ := response.Typify(m, utc)
b.ResetTimer()
for i := 0; i < b.N; i++ {
dur := minMsgTTL(m, mt)
if dur != 1000*time.Second {
b.Fatalf("Wrong minMsgTTL %d, expected %d", dur, 1000*time.Second)
}
}
}