dnsforward -- add upstream tests.
This commit is contained in:
parent
609523a59c
commit
2a1059107a
84
dnsforward/upstream_test.go
Normal file
84
dnsforward/upstream_test.go
Normal file
@ -0,0 +1,84 @@
|
||||
package dnsforward
|
||||
|
||||
import (
|
||||
"net"
|
||||
"testing"
|
||||
|
||||
"github.com/miekg/dns"
|
||||
)
|
||||
|
||||
func TestUpstreamDNS(t *testing.T) {
|
||||
upstreams := []string{
|
||||
"8.8.8.8:53",
|
||||
"1.1.1.1",
|
||||
"tcp://1.1.1.1:53",
|
||||
"176.103.130.130:5353",
|
||||
}
|
||||
for _, input := range upstreams {
|
||||
u, err := GetUpstream(input)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to choose upstream for %s: %s", input, err)
|
||||
}
|
||||
|
||||
checkUpstream(t, u, input)
|
||||
}
|
||||
}
|
||||
|
||||
func TestUpstreamTLS(t *testing.T) {
|
||||
upstreams := []string{
|
||||
"tls://1.1.1.1",
|
||||
"tls://9.9.9.9:853",
|
||||
"tls://security-filter-dns.cleanbrowsing.org",
|
||||
"tls://adult-filter-dns.cleanbrowsing.org:853",
|
||||
}
|
||||
for _, input := range upstreams {
|
||||
u, err := GetUpstream(input)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to choose upstream for %s: %s", input, err)
|
||||
}
|
||||
|
||||
checkUpstream(t, u, input)
|
||||
}
|
||||
}
|
||||
|
||||
func TestUpstreamHTTPS(t *testing.T) {
|
||||
upstreams := []string{
|
||||
"https://cloudflare-dns.com/dns-query",
|
||||
"https://dns.google.com/experimental",
|
||||
"https://doh.cleanbrowsing.org/doh/security-filter/",
|
||||
}
|
||||
for _, input := range upstreams {
|
||||
u, err := GetUpstream(input)
|
||||
if err != nil {
|
||||
t.Fatalf("Failed to choose upstream for %s: %s", input, err)
|
||||
}
|
||||
|
||||
checkUpstream(t, u, input)
|
||||
}
|
||||
}
|
||||
|
||||
func checkUpstream(t *testing.T, u Upstream, addr string) {
|
||||
t.Helper()
|
||||
|
||||
req := dns.Msg{}
|
||||
req.Id = dns.Id()
|
||||
req.RecursionDesired = true
|
||||
req.Question = []dns.Question{
|
||||
{Name: "google-public-dns-a.google.com.", Qtype: dns.TypeA, Qclass: dns.ClassINET},
|
||||
}
|
||||
|
||||
reply, err := u.Exchange(&req)
|
||||
if err != nil {
|
||||
t.Fatalf("Couldn't talk to upstream %s: %s", addr, err)
|
||||
}
|
||||
if len(reply.Answer) != 1 {
|
||||
t.Fatalf("DNS upstream %s returned reply with wrong number of answers - %d", addr, len(reply.Answer))
|
||||
}
|
||||
if a, ok := reply.Answer[0].(*dns.A); ok {
|
||||
if !net.IPv4(8, 8, 8, 8).Equal(a.A) {
|
||||
t.Fatalf("DNS upstream %s returned wrong answer instead of 8.8.8.8: %v", addr, a.A)
|
||||
}
|
||||
} else {
|
||||
t.Fatalf("DNS upstream %s returned wrong answer type instead of A: %v", addr, reply.Answer[0])
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user