aboutsummaryrefslogtreecommitdiff
path: root/plugin/kubernetes/xfr_test.go
diff options
context:
space:
mode:
authorGravatar Chris O'Haver <cohaver@infoblox.com> 2018-11-13 18:25:30 -0500
committerGravatar Miek Gieben <miek@miek.nl> 2018-11-13 23:25:30 +0000
commit7aafbe24cac838938a8fb0dbfe08d4870ae52d4b (patch)
tree7d8ee501a6dcc47ce950fb2d8620780fdf0ee6ea /plugin/kubernetes/xfr_test.go
parent4d52a71f0918eb6f5ebb9e2fc64a6473c1a6e72c (diff)
downloadcoredns-7aafbe24cac838938a8fb0dbfe08d4870ae52d4b.tar.gz
coredns-7aafbe24cac838938a8fb0dbfe08d4870ae52d4b.tar.zst
coredns-7aafbe24cac838938a8fb0dbfe08d4870ae52d4b.zip
plugin/kubernetes: Validate transfers are allowed (#2292)
* check allowed transfers * add tests for parsing, and comment about refactor
Diffstat (limited to '')
-rw-r--r--plugin/kubernetes/xfr_test.go36
1 files changed, 34 insertions, 2 deletions
diff --git a/plugin/kubernetes/xfr_test.go b/plugin/kubernetes/xfr_test.go
index 0117ebf06..78ad98208 100644
--- a/plugin/kubernetes/xfr_test.go
+++ b/plugin/kubernetes/xfr_test.go
@@ -15,7 +15,7 @@ import (
func TestKubernetesXFR(t *testing.T) {
k := New([]string{"cluster.local."})
k.APIConn = &APIConnServeTest{}
- k.TransferTo = []string{"127.0.0.1"}
+ k.TransferTo = []string{"10.240.0.1:53"}
k.Namespaces = map[string]bool{"testns": true}
ctx := context.TODO()
@@ -30,7 +30,12 @@ func TestKubernetesXFR(t *testing.T) {
if len(w.Msgs) == 0 {
t.Logf("%+v\n", w)
- t.Error("Did not get back a zone response")
+ t.Fatal("Did not get back a zone response")
+ }
+
+ if len(w.Msgs[0].Answer) == 0 {
+ t.Logf("%+v\n", w)
+ t.Fatal("Did not get back an answer")
}
// Ensure xfr starts with SOA
@@ -95,6 +100,33 @@ func TestKubernetesXFR(t *testing.T) {
}
}
+func TestKubernetesXFRNotAllowed(t *testing.T) {
+ k := New([]string{"cluster.local."})
+ k.APIConn = &APIConnServeTest{}
+ k.TransferTo = []string{"1.2.3.4:53"}
+ k.Namespaces = map[string]bool{"testns": true}
+
+ ctx := context.TODO()
+ w := dnstest.NewMultiRecorder(&test.ResponseWriter{})
+ dnsmsg := &dns.Msg{}
+ dnsmsg.SetAxfr(k.Zones[0])
+
+ _, err := k.ServeDNS(ctx, w, dnsmsg)
+ if err != nil {
+ t.Error(err)
+ }
+
+ if len(w.Msgs) == 0 {
+ t.Logf("%+v\n", w)
+ t.Fatal("Did not get back a zone response")
+ }
+
+ if len(w.Msgs[0].Answer) != 0 {
+ t.Logf("%+v\n", w)
+ t.Fatal("Got an answer, should not have")
+ }
+}
+
// difference shows what we're missing when comparing two RR slices
func difference(testRRs []dns.RR, gotRRs []dns.RR) []dns.RR {
expectedRRs := map[string]bool{}