aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Miek Gieben <miek@miek.nl> 2017-10-10 18:30:14 +0200
committerGravatar GitHub <noreply@github.com> 2017-10-10 18:30:14 +0200
commit7a64d1bbc36ec69c384fa71b7f28ab353a29e7ef (patch)
tree5837622f3b2b71058e9258b896874a5aa8657ad8
parent427aed6f5b465277dbc85be3ffbdccf0b88257ac (diff)
downloadcoredns-7a64d1bbc36ec69c384fa71b7f28ab353a29e7ef.tar.gz
coredns-7a64d1bbc36ec69c384fa71b7f28ab353a29e7ef.tar.zst
coredns-7a64d1bbc36ec69c384fa71b7f28ab353a29e7ef.zip
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.
-rw-r--r--plugin/cache/minttl_test.go42
-rw-r--r--plugin/pkg/response/typify.go2
2 files changed, 42 insertions, 2 deletions
diff --git a/plugin/cache/minttl_test.go b/plugin/cache/minttl_test.go
new file mode 100644
index 000000000..5ce4f2341
--- /dev/null
+++ b/plugin/cache/minttl_test.go
@@ -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)
+ }
+}
diff --git a/plugin/pkg/response/typify.go b/plugin/pkg/response/typify.go
index 7cfaab497..9faa17d7b 100644
--- a/plugin/pkg/response/typify.go
+++ b/plugin/pkg/response/typify.go
@@ -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
}