Added test case with IPV6 bind address for NS records, rewrote tests to use verify library and other code review feedback

pull/3353/head
Preetha Appan 2017-08-06 18:18:30 -05:00 committed by Frank Schroeder
parent 76319f751d
commit 7f34dc08a5
No known key found for this signature in database
GPG Key ID: 4D65C6EAEC87DECD
2 changed files with 68 additions and 22 deletions

View File

@ -287,7 +287,12 @@ func (d *DNSServer) nameservers(edns bool) (ns []dns.RR, extra []dns.RR) {
// get server names and store them in a map to randomize the output // get server names and store them in a map to randomize the output
servers := map[string]net.IP{} servers := map[string]net.IP{}
for name, addr := range d.agent.delegate.ServerAddrs() { for name, addr := range d.agent.delegate.ServerAddrs() {
ip := net.ParseIP(strings.Split(addr, ":")[0]) host, _, err := net.SplitHostPort(addr)
if err != nil {
d.logger.Println("[WARN] Unable to parse address %v, got error: %v", addr, err)
continue
}
ip := net.ParseIP(host)
if ip == nil { if ip == nil {
continue continue
} }

View File

@ -914,36 +914,75 @@ func TestDNS_NSRecords(t *testing.T) {
t.Fatalf("err: %v", err) t.Fatalf("err: %v", err)
} }
if len(in.Answer) != 1 { wantAnswer := []dns.RR{
t.Fatalf("Bad: %#v", in) &dns.NS{
Hdr: dns.RR_Header{Name: "consul.", Rrtype: dns.TypeNS, Class: dns.ClassINET, Ttl: 0, Rdlength: 0x13},
Ns: "server1.node.dc1.consul.",
},
}
verify.Values(t, "answer", in.Answer, wantAnswer)
wantExtra := []dns.RR{
&dns.A{
Hdr: dns.RR_Header{Name: "server1.node.dc1.consul.", Rrtype: dns.TypeA, Class: dns.ClassINET, Rdlength: 0x4, Ttl: 0},
A: net.ParseIP("127.0.0.1").To4(),
},
} }
nsRec, ok := in.Answer[0].(*dns.NS) verify.Values(t, "extra", in.Extra, wantExtra)
if !ok {
t.Fatalf("Bad: %#v", in.Answer[0]) }
}
if nsRec.Ns != "server1.node.dc1.consul." { func TestDNS_NSRecords_IPV6(t *testing.T) {
t.Fatalf("Bad: %#v", in.Answer[0]) t.Parallel()
} cfg := TestConfig()
if nsRec.Hdr.Ttl != 0 { cfg.Domain = "CONSUL."
t.Fatalf("Bad: %#v", in.Answer[0]) cfg.NodeName = "server1"
cfg.AdvertiseAddr = "::1"
cfg.AdvertiseAddrWan = "::1"
a := NewTestAgent(t.Name(), cfg)
defer a.Shutdown()
// Register node
args := &structs.RegisterRequest{
Datacenter: "dc1",
Node: "foo",
Address: "127.0.0.1",
TaggedAddresses: map[string]string{
"wan": "127.0.0.2",
},
} }
if len(in.Extra) != 1 { var out struct{}
t.Fatalf("Bad: %#v", in.Extra) if err := a.RPC("Catalog.Register", args, &out); err != nil {
t.Fatalf("err: %v", err)
} }
aRec, ok := in.Extra[0].(*dns.A) m := new(dns.Msg)
if !ok { m.SetQuestion("server1.node.dc1.consul.", dns.TypeNS)
t.Fatalf("Bad: %#v", in.Extra)
c := new(dns.Client)
addr, _ := a.Config.ClientListener("", a.Config.Ports.DNS)
in, _, err := c.Exchange(m, addr.String())
if err != nil {
t.Fatalf("err: %v", err)
} }
if aRec.A.String() != "127.0.0.1" {
t.Fatalf("Bad: %#v", in.Extra) wantAnswer := []dns.RR{
&dns.NS{
Hdr: dns.RR_Header{Name: "consul.", Rrtype: dns.TypeNS, Class: dns.ClassINET, Ttl: 0, Rdlength: 0x2},
Ns: "server1.node.dc1.consul.",
},
} }
if aRec.Hdr.Name != "server1.node.dc1.consul." { verify.Values(t, "answer", in.Answer, wantAnswer)
t.Fatalf("Bad: %#v", in.Extra) wantExtra := []dns.RR{
&dns.AAAA{
Hdr: dns.RR_Header{Name: "server1.node.dc1.consul.", Rrtype: dns.TypeAAAA, Class: dns.ClassINET, Rdlength: 0x10, Ttl: 0},
AAAA: net.ParseIP("::1"),
},
} }
verify.Values(t, "extra", in.Extra, wantExtra)
} }
func TestDNS_ExternalServiceToConsulCNAMENestedLookup(t *testing.T) { func TestDNS_ExternalServiceToConsulCNAMENestedLookup(t *testing.T) {
@ -4773,7 +4812,9 @@ func TestDNSInvalidRegex(t *testing.T) {
{"Valid Hostname", "testnode", false}, {"Valid Hostname", "testnode", false},
{"Valid Hostname", "test-node", false}, {"Valid Hostname", "test-node", false},
{"Invalid Hostname with special chars", "test#$$!node", true}, {"Invalid Hostname with special chars", "test#$$!node", true},
{"Invalid Hostname with special chars in the end", "test-node%^", true}, {"Invalid Hostname with special chars in the end", "testnode%^", true},
{"Whitespace", " ", true},
{"Only special chars", "./$", true},
} }
for _, test := range tests { for _, test := range tests {
t.Run(test.desc, func(t *testing.T) { t.Run(test.desc, func(t *testing.T) {