comandy/dns_test.go

90 lines
1.7 KiB
Go
Raw Normal View History

2024-04-15 17:10:06 +09:00
package main
import (
"context"
"crypto/tls"
2024-04-16 15:27:06 +09:00
"fmt"
2024-04-15 17:10:06 +09:00
"net"
"testing"
2024-04-17 01:12:52 +09:00
"time"
2024-04-15 17:10:06 +09:00
"github.com/fumiama/terasu"
)
func TestResolver(t *testing.T) {
t.Log("canUseIPv6:", canUseIPv6.Get())
2024-04-17 01:12:52 +09:00
addrs, err := resolver.LookupHost(context.TODO(), "api.mangacopy.com")
2024-04-15 17:10:06 +09:00
if err != nil {
t.Fatal(err)
}
t.Log(addrs)
2024-04-17 01:12:52 +09:00
if len(addrs) == 0 {
t.Fail()
}
2024-04-15 17:10:06 +09:00
}
func TestDNS(t *testing.T) {
if canUseIPv6.Get() {
2024-04-16 15:27:06 +09:00
dotv6servers.test()
2024-04-15 17:10:06 +09:00
}
2024-04-16 15:27:06 +09:00
dotv4servers.test()
2024-04-17 01:12:52 +09:00
for i := 0; i < 100; i++ {
addrs, err := resolver.LookupHost(context.TODO(), "api.mangacopy.com")
if err != nil {
t.Fatal(err)
}
t.Log(addrs)
if len(addrs) == 0 {
t.Fail()
}
time.Sleep(time.Millisecond * 50)
}
}
func TestBadDNS(t *testing.T) {
if canUseIPv6.Get() {
dotv6servers = dnsservers{
m: map[string][]*dnsstat{},
}
dotv6servers.add(map[string][]string{"test.bad.host": {"169.254.122.111"}})
} else {
dotv4servers = dnsservers{
m: map[string][]*dnsstat{},
}
dotv4servers.add(map[string][]string{"test.bad.host": {"169.254.122.111:853"}})
}
for i := 0; i < 10; i++ {
addrs, err := resolver.LookupHost(context.TODO(), "api.mangacopy.com")
t.Log(err)
if err == nil && len(addrs) > 0 {
t.Fatal("unexpected")
}
time.Sleep(time.Millisecond * 50)
}
2024-04-15 17:10:06 +09:00
}
2024-04-16 15:27:06 +09:00
func (ds *dnsservers) test() {
2024-04-15 17:10:06 +09:00
ds.RLock()
defer ds.RUnlock()
for host, addrs := range ds.m {
for _, addr := range addrs {
if !addr.E {
continue
}
2024-04-16 15:27:06 +09:00
fmt.Println("dial:", host, addr.A)
2024-04-15 17:10:06 +09:00
conn, err := net.Dial("tcp", addr.A)
if err != nil {
continue
}
2024-04-16 15:27:06 +09:00
tlsConn := tls.Client(conn, &tls.Config{ServerName: host})
err = terasu.Use(tlsConn).Handshake()
2024-04-15 17:10:06 +09:00
_ = tlsConn.Close()
if err == nil {
2024-04-16 15:27:06 +09:00
fmt.Println("succ:", host, addr.A)
2024-04-15 17:10:06 +09:00
continue
}
2024-04-16 15:27:06 +09:00
fmt.Println("fail:", host, addr.A)
2024-04-15 17:10:06 +09:00
}
}
}