2022-06-02 11:51:21 +02:00
|
|
|
package netx
|
2021-02-02 12:05:47 +01:00
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"strings"
|
|
|
|
"testing"
|
|
|
|
|
2022-01-05 17:17:20 +01:00
|
|
|
"github.com/ooni/probe-cli/v3/internal/netxlite"
|
2022-06-02 00:50:55 +02:00
|
|
|
"github.com/ooni/probe-cli/v3/internal/tracex"
|
2021-02-02 12:05:47 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func TestNewDNSClientInvalidURL(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(Config{}, "\t\t\t")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err == nil || !strings.HasSuffix(err.Error(), "invalid control character in URL") {
|
|
|
|
t.Fatal("not the error we expected")
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
if dnsclient != nil {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("expected nil resolver here")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientUnsupportedScheme(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(Config{}, "antani:///")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err == nil || err.Error() != "unsupported resolver scheme" {
|
|
|
|
t.Fatal("not the error we expected")
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
if dnsclient != nil {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("expected nil resolver here")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientGoogleDoH(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
|
|
|
Config{}, "doh://google")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
if _, ok := r.Transport().(*netxlite.DNSOverHTTPSTransport); !ok {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientCloudflareDoH(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
|
|
|
Config{}, "doh://cloudflare")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
if _, ok := r.Transport().(*netxlite.DNSOverHTTPSTransport); !ok {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientCloudflareDoHSaver(t *testing.T) {
|
2022-05-31 21:53:01 +02:00
|
|
|
saver := new(tracex.Saver)
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
2022-06-02 18:18:49 +02:00
|
|
|
Config{Saver: saver}, "doh://cloudflare")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-06-01 23:15:47 +02:00
|
|
|
txp, ok := r.Transport().(*tracex.DNSTransportSaver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
if _, ok := txp.DNSTransport.(*netxlite.DNSOverHTTPSTransport); !ok {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientUDP(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
|
|
|
Config{}, "udp://8.8.8.8:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
if _, ok := r.Transport().(*netxlite.DNSOverUDPTransport); !ok {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientUDPDNSSaver(t *testing.T) {
|
2022-05-31 21:53:01 +02:00
|
|
|
saver := new(tracex.Saver)
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
2022-06-02 18:18:49 +02:00
|
|
|
Config{Saver: saver}, "udp://8.8.8.8:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-06-01 23:15:47 +02:00
|
|
|
txp, ok := r.Transport().(*tracex.DNSTransportSaver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
if _, ok := txp.DNSTransport.(*netxlite.DNSOverUDPTransport); !ok {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientTCP(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
|
|
|
Config{}, "tcp://8.8.8.8:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
txp, ok := r.Transport().(*netxlite.DNSOverTCPTransport)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
if txp.Network() != "tcp" {
|
|
|
|
t.Fatal("not the Network we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientTCPDNSSaver(t *testing.T) {
|
2022-05-31 21:53:01 +02:00
|
|
|
saver := new(tracex.Saver)
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
2022-06-02 18:18:49 +02:00
|
|
|
Config{Saver: saver}, "tcp://8.8.8.8:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-06-01 23:15:47 +02:00
|
|
|
txp, ok := r.Transport().(*tracex.DNSTransportSaver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
dotcp, ok := txp.DNSTransport.(*netxlite.DNSOverTCPTransport)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
if dotcp.Network() != "tcp" {
|
|
|
|
t.Fatal("not the Network we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientDoT(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
|
|
|
Config{}, "dot://8.8.8.8:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
txp, ok := r.Transport().(*netxlite.DNSOverTCPTransport)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
if txp.Network() != "dot" {
|
|
|
|
t.Fatal("not the Network we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientDoTDNSSaver(t *testing.T) {
|
2022-05-31 21:53:01 +02:00
|
|
|
saver := new(tracex.Saver)
|
2022-06-02 11:51:21 +02:00
|
|
|
dnsclient, err := NewDNSClient(
|
2022-06-02 18:18:49 +02:00
|
|
|
Config{Saver: saver}, "dot://8.8.8.8:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
r, ok := dnsclient.(*netxlite.SerialResolver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the resolver we expected")
|
|
|
|
}
|
2022-06-01 23:15:47 +02:00
|
|
|
txp, ok := r.Transport().(*tracex.DNSTransportSaver)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
2022-05-14 17:38:31 +02:00
|
|
|
dotls, ok := txp.DNSTransport.(*netxlite.DNSOverTCPTransport)
|
2021-02-02 12:05:47 +01:00
|
|
|
if !ok {
|
|
|
|
t.Fatal("not the transport we expected")
|
|
|
|
}
|
|
|
|
if dotls.Network() != "dot" {
|
|
|
|
t.Fatal("not the Network we expected")
|
|
|
|
}
|
|
|
|
dnsclient.CloseIdleConnections()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSCLientDoTWithoutPort(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
c, err := NewDNSClientWithOverrides(
|
|
|
|
Config{}, "dot://8.8.8.8", "", "8.8.8.8", "")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
if c.Address() != "8.8.8.8:853" {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("expected default port to be added")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSCLientTCPWithoutPort(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
c, err := NewDNSClientWithOverrides(
|
|
|
|
Config{}, "tcp://8.8.8.8", "", "8.8.8.8", "")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
if c.Address() != "8.8.8.8:53" {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("expected default port to be added")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSCLientUDPWithoutPort(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
c, err := NewDNSClientWithOverrides(
|
|
|
|
Config{}, "udp://8.8.8.8", "", "8.8.8.8", "")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err != nil {
|
|
|
|
t.Fatal(err)
|
|
|
|
}
|
2022-01-10 11:53:06 +01:00
|
|
|
if c.Address() != "8.8.8.8:53" {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatal("expected default port to be added")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientBadDoTEndpoint(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
_, err := NewDNSClient(
|
|
|
|
Config{}, "dot://bad:endpoint:53")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err == nil || !strings.Contains(err.Error(), "too many colons in address") {
|
|
|
|
t.Fatal("expected error with bad endpoint")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientBadTCPEndpoint(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
_, err := NewDNSClient(
|
|
|
|
Config{}, "tcp://bad:endpoint:853")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err == nil || !strings.Contains(err.Error(), "too many colons in address") {
|
|
|
|
t.Fatal("expected error with bad endpoint")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSClientBadUDPEndpoint(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
_, err := NewDNSClient(
|
|
|
|
Config{}, "udp://bad:endpoint:853")
|
2021-02-02 12:05:47 +01:00
|
|
|
if err == nil || !strings.Contains(err.Error(), "too many colons in address") {
|
|
|
|
t.Fatal("expected error with bad endpoint")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestNewDNSCLientWithInvalidTLSVersion(t *testing.T) {
|
2022-06-02 11:51:21 +02:00
|
|
|
_, err := NewDNSClientWithOverrides(
|
|
|
|
Config{}, "dot://8.8.8.8", "", "", "TLSv999")
|
2021-06-25 12:39:45 +02:00
|
|
|
if !errors.Is(err, netxlite.ErrInvalidTLSVersion) {
|
2021-02-02 12:05:47 +01:00
|
|
|
t.Fatalf("not the error we expected: %+v", err)
|
|
|
|
}
|
|
|
|
}
|