mw/kubernetes: test cleanup (#1020)
Move tests infra to look like all other middleware, and some small cleanups.
This commit is contained in:
parent
9bcddc5c16
commit
9452a0a3bc
4 changed files with 60 additions and 53 deletions
|
@ -10,23 +10,19 @@ import (
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
)
|
)
|
||||||
|
|
||||||
var podModeDisabledCases = map[string](test.Case){
|
var podModeDisabledCases = []test.Case{
|
||||||
|
{
|
||||||
"A Record Pod mode = Case 1": {
|
|
||||||
Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Error: errPodsDisabled,
|
Error: errPodsDisabled,
|
||||||
Answer: []dns.RR{},
|
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
"A Record Pod mode = Case 2": {
|
|
||||||
Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Error: errPodsDisabled,
|
Error: errPodsDisabled,
|
||||||
Answer: []dns.RR{},
|
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
|
@ -41,14 +37,14 @@ func TestServeDNSModeDisabled(t *testing.T) {
|
||||||
k.podMode = podModeDisabled
|
k.podMode = podModeDisabled
|
||||||
ctx := context.TODO()
|
ctx := context.TODO()
|
||||||
|
|
||||||
for testname, tc := range podModeDisabledCases {
|
for i, tc := range podModeDisabledCases {
|
||||||
r := tc.Msg()
|
r := tc.Msg()
|
||||||
|
|
||||||
w := dnsrecorder.New(&test.ResponseWriter{})
|
w := dnsrecorder.New(&test.ResponseWriter{})
|
||||||
|
|
||||||
_, err := k.ServeDNS(ctx, w, r)
|
_, err := k.ServeDNS(ctx, w, r)
|
||||||
if err != tc.Error {
|
if err != tc.Error {
|
||||||
t.Errorf("%v expected no error, got %v\n", testname, err)
|
t.Errorf("Test %d expected no error, got %v", i, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if tc.Error != nil {
|
if tc.Error != nil {
|
||||||
|
@ -57,7 +53,7 @@ func TestServeDNSModeDisabled(t *testing.T) {
|
||||||
|
|
||||||
resp := w.Msg
|
resp := w.Msg
|
||||||
if resp == nil {
|
if resp == nil {
|
||||||
t.Fatalf("got nil message and no error for %q: %s %d", testname, r.Question[0].Name, r.Question[0].Qtype)
|
t.Fatalf("Test %d, got nil message and no error for %q", i, r.Question[0].Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
test.SortAndCheck(t, resp, tc)
|
test.SortAndCheck(t, resp, tc)
|
||||||
|
|
|
@ -10,17 +10,15 @@ import (
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
)
|
)
|
||||||
|
|
||||||
var podModeInsecureCases = map[string](test.Case){
|
var podModeInsecureCases = []test.Case{
|
||||||
|
{
|
||||||
"A Record Pod mode = Case 1": {
|
|
||||||
Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.A("10-240-0-1.podns.pod.cluster.local. 0 IN A 10.240.0.1"),
|
test.A("10-240-0-1.podns.pod.cluster.local. 0 IN A 10.240.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
"A Record Pod mode = Case 2": {
|
|
||||||
Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
|
@ -37,14 +35,14 @@ func TestServeDNSModeInsecure(t *testing.T) {
|
||||||
ctx := context.TODO()
|
ctx := context.TODO()
|
||||||
k.podMode = podModeInsecure
|
k.podMode = podModeInsecure
|
||||||
|
|
||||||
for testname, tc := range podModeInsecureCases {
|
for i, tc := range podModeInsecureCases {
|
||||||
r := tc.Msg()
|
r := tc.Msg()
|
||||||
|
|
||||||
w := dnsrecorder.New(&test.ResponseWriter{})
|
w := dnsrecorder.New(&test.ResponseWriter{})
|
||||||
|
|
||||||
_, err := k.ServeDNS(ctx, w, r)
|
_, err := k.ServeDNS(ctx, w, r)
|
||||||
if err != tc.Error {
|
if err != tc.Error {
|
||||||
t.Errorf("%v expected no error, got %v\n", testname, err)
|
t.Errorf("Test %d expected no error, got %v", i, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if tc.Error != nil {
|
if tc.Error != nil {
|
||||||
|
@ -53,7 +51,7 @@ func TestServeDNSModeInsecure(t *testing.T) {
|
||||||
|
|
||||||
resp := w.Msg
|
resp := w.Msg
|
||||||
if resp == nil {
|
if resp == nil {
|
||||||
t.Fatalf("got nil message and no error for %q: %s %d", testname, r.Question[0].Name, r.Question[0].Qtype)
|
t.Fatalf("Test %d, got nil message and no error for %q", i, r.Question[0].Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
test.SortAndCheck(t, resp, tc)
|
test.SortAndCheck(t, resp, tc)
|
||||||
|
|
|
@ -10,20 +10,17 @@ import (
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
)
|
)
|
||||||
|
|
||||||
var podModeVerifiedCases = map[string](test.Case){
|
var podModeVerifiedCases = []test.Case{
|
||||||
|
{
|
||||||
"A Record Pod mode = Case 1": {
|
|
||||||
Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
Qname: "10-240-0-1.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.A("10-240-0-1.podns.pod.cluster.local. 0 IN A 10.240.0.1"),
|
test.A("10-240-0-1.podns.pod.cluster.local. 0 IN A 10.240.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
"A Record Pod mode = Case 2": {
|
|
||||||
Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
Qname: "172-0-0-2.podns.pod.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Answer: []dns.RR{},
|
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
|
@ -38,14 +35,14 @@ func TestServeDNSModeVerified(t *testing.T) {
|
||||||
ctx := context.TODO()
|
ctx := context.TODO()
|
||||||
k.podMode = podModeVerified
|
k.podMode = podModeVerified
|
||||||
|
|
||||||
for testname, tc := range podModeVerifiedCases {
|
for i, tc := range podModeVerifiedCases {
|
||||||
r := tc.Msg()
|
r := tc.Msg()
|
||||||
|
|
||||||
w := dnsrecorder.New(&test.ResponseWriter{})
|
w := dnsrecorder.New(&test.ResponseWriter{})
|
||||||
|
|
||||||
_, err := k.ServeDNS(ctx, w, r)
|
_, err := k.ServeDNS(ctx, w, r)
|
||||||
if err != tc.Error {
|
if err != tc.Error {
|
||||||
t.Errorf("%v expected no error, got %v\n", testname, err)
|
t.Errorf("Test %d expected no error, got %v", i, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if tc.Error != nil {
|
if tc.Error != nil {
|
||||||
|
@ -54,7 +51,7 @@ func TestServeDNSModeVerified(t *testing.T) {
|
||||||
|
|
||||||
resp := w.Msg
|
resp := w.Msg
|
||||||
if resp == nil {
|
if resp == nil {
|
||||||
t.Fatalf("got nil message and no error for %q: %s %d", testname, r.Question[0].Name, r.Question[0].Qtype)
|
t.Fatalf("Test %d, got nil message and no error for %q", i, r.Question[0].Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
test.SortAndCheck(t, resp, tc)
|
test.SortAndCheck(t, resp, tc)
|
||||||
|
|
|
@ -11,54 +11,61 @@ import (
|
||||||
"k8s.io/client-go/1.5/pkg/api"
|
"k8s.io/client-go/1.5/pkg/api"
|
||||||
)
|
)
|
||||||
|
|
||||||
var dnsTestCases = map[string](test.Case){
|
var dnsTestCases = []test.Case{
|
||||||
"A Service": {
|
// A Service
|
||||||
|
{
|
||||||
Qname: "svc1.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "svc1.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.A("svc1.testns.svc.cluster.local. 5 IN A 10.0.0.1"),
|
test.A("svc1.testns.svc.cluster.local. 5 IN A 10.0.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"A Service (wildcard)": {
|
// A Service (wildcard)
|
||||||
|
{
|
||||||
Qname: "svc1.*.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "svc1.*.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.A("svc1.*.svc.cluster.local. 5 IN A 10.0.0.1"),
|
test.A("svc1.*.svc.cluster.local. 5 IN A 10.0.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"SRV Service (wildcard, root)": {
|
{
|
||||||
Qname: "svc1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
Qname: "svc1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{test.SRV("svc1.testns.svc.cluster.local. 303 IN SRV 0 100 80 svc1.testns.svc.cluster.local.")},
|
Answer: []dns.RR{test.SRV("svc1.testns.svc.cluster.local. 303 IN SRV 0 100 80 svc1.testns.svc.cluster.local.")},
|
||||||
Extra: []dns.RR{test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1")},
|
Extra: []dns.RR{test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1")},
|
||||||
},
|
},
|
||||||
"SRV Service (wildcard)": {
|
// SRV Service (wildcard)
|
||||||
|
{
|
||||||
Qname: "svc1.*.svc.cluster.local.", Qtype: dns.TypeSRV,
|
Qname: "svc1.*.svc.cluster.local.", Qtype: dns.TypeSRV,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{test.SRV("svc1.*.svc.cluster.local. 303 IN SRV 0 100 80 svc1.testns.svc.cluster.local.")},
|
Answer: []dns.RR{test.SRV("svc1.*.svc.cluster.local. 303 IN SRV 0 100 80 svc1.testns.svc.cluster.local.")},
|
||||||
Extra: []dns.RR{test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1")},
|
Extra: []dns.RR{test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1")},
|
||||||
},
|
},
|
||||||
"SRV Service (wildcards)": {
|
// SRV Service (wildcards)
|
||||||
|
{
|
||||||
Qname: "*.any.svc1.*.svc.cluster.local.", Qtype: dns.TypeSRV,
|
Qname: "*.any.svc1.*.svc.cluster.local.", Qtype: dns.TypeSRV,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{test.SRV("*.any.svc1.*.svc.cluster.local. 303 IN SRV 0 100 80 svc1.testns.svc.cluster.local.")},
|
Answer: []dns.RR{test.SRV("*.any.svc1.*.svc.cluster.local. 303 IN SRV 0 100 80 svc1.testns.svc.cluster.local.")},
|
||||||
Extra: []dns.RR{test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1")},
|
Extra: []dns.RR{test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1")},
|
||||||
},
|
},
|
||||||
"A Service (wildcards)": {
|
// A Service (wildcards)
|
||||||
|
{
|
||||||
Qname: "*.any.svc1.*.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "*.any.svc1.*.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.A("*.any.svc1.*.svc.cluster.local. 303 IN A 10.0.0.1"),
|
test.A("*.any.svc1.*.svc.cluster.local. 303 IN A 10.0.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"SRV Service Not udp/tcp": {
|
// SRV Service Not udp/tcp
|
||||||
|
{
|
||||||
Qname: "*._not-udp-or-tcp.svc1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
Qname: "*._not-udp-or-tcp.svc1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"SRV Service": {
|
// SRV Service
|
||||||
|
{
|
||||||
Qname: "_http._tcp.svc1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
Qname: "_http._tcp.svc1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
|
@ -68,7 +75,8 @@ var dnsTestCases = map[string](test.Case){
|
||||||
test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1"),
|
test.A("svc1.testns.svc.cluster.local. 303 IN A 10.0.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"A Service (Headless)": {
|
// A Service (Headless)
|
||||||
|
{
|
||||||
Qname: "hdls1.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "hdls1.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
|
@ -76,7 +84,8 @@ var dnsTestCases = map[string](test.Case){
|
||||||
test.A("hdls1.testns.svc.cluster.local. 303 IN A 172.0.0.3"),
|
test.A("hdls1.testns.svc.cluster.local. 303 IN A 172.0.0.3"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"SRV Service (Headless)": {
|
// SRV Service (Headless)
|
||||||
|
{
|
||||||
Qname: "_http._tcp.hdls1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
Qname: "_http._tcp.hdls1.testns.svc.cluster.local.", Qtype: dns.TypeSRV,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
|
@ -88,49 +97,56 @@ var dnsTestCases = map[string](test.Case){
|
||||||
test.A("172-0-0-3.hdls1.testns.svc.cluster.local. 303 IN A 172.0.0.3"),
|
test.A("172-0-0-3.hdls1.testns.svc.cluster.local. 303 IN A 172.0.0.3"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"CNAME External": {
|
// CNAME External
|
||||||
|
{
|
||||||
Qname: "external.testns.svc.cluster.local.", Qtype: dns.TypeCNAME,
|
Qname: "external.testns.svc.cluster.local.", Qtype: dns.TypeCNAME,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.CNAME("external.testns.svc.cluster.local. 303 IN CNAME ext.interwebs.test."),
|
test.CNAME("external.testns.svc.cluster.local. 303 IN CNAME ext.interwebs.test."),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"AAAA Service (existing service)": {
|
// AAAA Service (existing service)
|
||||||
|
{
|
||||||
Qname: "svc1.testns.svc.cluster.local.", Qtype: dns.TypeAAAA,
|
Qname: "svc1.testns.svc.cluster.local.", Qtype: dns.TypeAAAA,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"AAAA Service (non-existing service)": {
|
// AAAA Service (non-existing service)
|
||||||
|
{
|
||||||
Qname: "svc0.testns.svc.cluster.local.", Qtype: dns.TypeAAAA,
|
Qname: "svc0.testns.svc.cluster.local.", Qtype: dns.TypeAAAA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"A Service (non-existing service)": {
|
// A Service (non-existing service)
|
||||||
|
{
|
||||||
Qname: "svc0.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "svc0.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"TXT Schema": {
|
// TXT Schema
|
||||||
|
{
|
||||||
Qname: "dns-version.cluster.local.", Qtype: dns.TypeTXT,
|
Qname: "dns-version.cluster.local.", Qtype: dns.TypeTXT,
|
||||||
Rcode: dns.RcodeSuccess,
|
Rcode: dns.RcodeSuccess,
|
||||||
Answer: []dns.RR{
|
Answer: []dns.RR{
|
||||||
test.TXT("dns-version.cluster.local 28800 IN TXT 1.0.1"),
|
test.TXT("dns-version.cluster.local 28800 IN TXT 1.0.1"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"A Service (Headless) does not exist": {
|
// A Service (Headless) does not exist
|
||||||
|
{
|
||||||
Qname: "bogusendpoint.hdls1.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "bogusendpoint.hdls1.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
test.SOA("cluster.local. 300 IN SOA ns.dns.cluster.local. hostmaster.cluster.local. 1499347823 7200 1800 86400 60"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
"A Service does not exist": {
|
// A Service does not exist
|
||||||
|
{
|
||||||
Qname: "bogusendpoint.svc0.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
Qname: "bogusendpoint.svc0.testns.svc.cluster.local.", Qtype: dns.TypeA,
|
||||||
Rcode: dns.RcodeNameError,
|
Rcode: dns.RcodeNameError,
|
||||||
Ns: []dns.RR{
|
Ns: []dns.RR{
|
||||||
|
@ -146,14 +162,14 @@ func TestServeDNS(t *testing.T) {
|
||||||
k.Next = test.NextHandler(dns.RcodeSuccess, nil)
|
k.Next = test.NextHandler(dns.RcodeSuccess, nil)
|
||||||
ctx := context.TODO()
|
ctx := context.TODO()
|
||||||
|
|
||||||
for testname, tc := range dnsTestCases {
|
for i, tc := range dnsTestCases {
|
||||||
r := tc.Msg()
|
r := tc.Msg()
|
||||||
|
|
||||||
w := dnsrecorder.New(&test.ResponseWriter{})
|
w := dnsrecorder.New(&test.ResponseWriter{})
|
||||||
|
|
||||||
_, err := k.ServeDNS(ctx, w, r)
|
_, err := k.ServeDNS(ctx, w, r)
|
||||||
if err != tc.Error {
|
if err != tc.Error {
|
||||||
t.Errorf("%v expected no error, got %v\n", testname, err)
|
t.Errorf("Test %d expected no error, got %v", i, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if tc.Error != nil {
|
if tc.Error != nil {
|
||||||
|
@ -162,7 +178,7 @@ func TestServeDNS(t *testing.T) {
|
||||||
|
|
||||||
resp := w.Msg
|
resp := w.Msg
|
||||||
if resp == nil {
|
if resp == nil {
|
||||||
t.Fatalf("got nil message and no error for %q: %s %d", testname, r.Question[0].Name, r.Question[0].Qtype)
|
t.Fatalf("Test %d, got nil message and no error for %q", i, r.Question[0].Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Before sorting, make sure that CNAMES do not appear after their target records
|
// Before sorting, make sure that CNAMES do not appear after their target records
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue