plugin/cache: add minttl test (#1141)
See https://github.com/kubernetes/kubernetes/pull/53604, explicitaly add test to make sure we do the right thing.
This commit is contained in:
parent
427aed6f5b
commit
7a64d1bbc3
2 changed files with 42 additions and 2 deletions
42
plugin/cache/minttl_test.go
vendored
Normal file
42
plugin/cache/minttl_test.go
vendored
Normal file
|
@ -0,0 +1,42 @@
|
|||
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)
|
||||
}
|
||||
}
|
|
@ -99,8 +99,6 @@ func Typify(m *dns.Msg, t time.Time) (Type, *dns.OPT) {
|
|||
}
|
||||
}
|
||||
|
||||
// Check length of different sections, and drop stuff that is just to large? TODO(miek).
|
||||
|
||||
if soa && m.Rcode == dns.RcodeSuccess {
|
||||
return NoData, opt
|
||||
}
|
||||
|
|
Loading…
Add table
Reference in a new issue