mirror of https://github.com/hashicorp/consul
Added test case with IPV6 bind address for NS records, rewrote tests to use verify library and other code review feedback
parent
76319f751d
commit
7f34dc08a5
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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) {
|
||||||
|
|
Loading…
Reference in New Issue