aboutsummaryrefslogtreecommitdiff
path: root/plugin/kubernetes/handler_pod_verified_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'plugin/kubernetes/handler_pod_verified_test.go')
-rw-r--r--plugin/kubernetes/handler_pod_verified_test.go59
1 files changed, 59 insertions, 0 deletions
diff --git a/plugin/kubernetes/handler_pod_verified_test.go b/plugin/kubernetes/handler_pod_verified_test.go
new file mode 100644
index 000000000..ea585cc6a
--- /dev/null
+++ b/plugin/kubernetes/handler_pod_verified_test.go
@@ -0,0 +1,59 @@
+package kubernetes
+
+import (
+ "testing"
+
+ "github.com/coredns/coredns/plugin/pkg/dnsrecorder"
+ "github.com/coredns/coredns/plugin/test"
+
+ "github.com/miekg/dns"
+ "golang.org/x/net/context"
+)
+
+var podModeVerifiedCases = []test.Case{
+ {
+ Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
+ Rcode: dns.RcodeSuccess,
+ Answer: []dns.RR{
+ test.A("10-240-0-1.podns.pod.cluster.local. 0 IN A 10.240.0.1"),
+ },
+ },
+ {
+ Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
+ Rcode: dns.RcodeNameError,
+ Ns: []dns.RR{
+ test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
+ },
+ },
+}
+
+func TestServeDNSModeVerified(t *testing.T) {
+
+ k := New([]string{"cluster.local."})
+ k.APIConn = &APIConnServeTest{}
+ k.Next = test.NextHandler(dns.RcodeSuccess, nil)
+ ctx := context.TODO()
+ k.podMode = podModeVerified
+
+ for i, tc := range podModeVerifiedCases {
+ r := tc.Msg()
+
+ w := dnsrecorder.New(&test.ResponseWriter{})
+
+ _, err := k.ServeDNS(ctx, w, r)
+ if err != tc.Error {
+ t.Errorf("Test %d expected no error, got %v", i, err)
+ return
+ }
+ if tc.Error != nil {
+ continue
+ }
+
+ resp := w.Msg
+ if resp == nil {
+ t.Fatalf("Test %d, got nil message and no error for %q", i, r.Question[0].Name)
+ }
+
+ test.SortAndCheck(t, resp, tc)
+ }
+}