2016-04-11 07:56:38 +01:00
|
|
|
package test
|
2016-04-07 08:03:57 +01:00
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"net"
|
|
|
|
|
"sync"
|
2016-08-14 12:57:49 -06:00
|
|
|
"testing"
|
2016-04-07 08:03:57 +01:00
|
|
|
"time"
|
|
|
|
|
|
|
|
|
|
"github.com/miekg/dns"
|
|
|
|
|
)
|
|
|
|
|
|
2016-08-14 12:57:49 -06:00
|
|
|
func TCPServer(t *testing.T, laddr string) (*dns.Server, string, error) {
|
2016-04-07 08:03:57 +01:00
|
|
|
l, err := net.Listen("tcp", laddr)
|
|
|
|
|
if err != nil {
|
|
|
|
|
return nil, "", err
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
server := &dns.Server{Listener: l, ReadTimeout: time.Hour, WriteTimeout: time.Hour}
|
|
|
|
|
|
|
|
|
|
waitLock := sync.Mutex{}
|
|
|
|
|
waitLock.Lock()
|
2016-08-14 12:57:49 -06:00
|
|
|
server.NotifyStartedFunc = func() { t.Logf("started TCP server on %s", l.Addr()); waitLock.Unlock() }
|
2016-04-07 08:03:57 +01:00
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
|
server.ActivateAndServe()
|
|
|
|
|
l.Close()
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
waitLock.Lock()
|
|
|
|
|
return server, l.Addr().String(), nil
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-14 12:57:49 -06:00
|
|
|
func UDPServer(t *testing.T, laddr string) (*dns.Server, string, error) {
|
2016-04-07 08:03:57 +01:00
|
|
|
pc, err := net.ListenPacket("udp", laddr)
|
|
|
|
|
if err != nil {
|
2016-08-14 12:57:49 -06:00
|
|
|
return nil, "", err
|
2016-04-07 08:03:57 +01:00
|
|
|
}
|
|
|
|
|
server := &dns.Server{PacketConn: pc, ReadTimeout: time.Hour, WriteTimeout: time.Hour}
|
|
|
|
|
|
|
|
|
|
waitLock := sync.Mutex{}
|
|
|
|
|
waitLock.Lock()
|
2016-08-14 12:57:49 -06:00
|
|
|
server.NotifyStartedFunc = func() { t.Logf("started UDP server on %s", pc.LocalAddr()); waitLock.Unlock() }
|
2016-04-07 08:03:57 +01:00
|
|
|
|
|
|
|
|
go func() {
|
|
|
|
|
server.ActivateAndServe()
|
|
|
|
|
pc.Close()
|
|
|
|
|
}()
|
|
|
|
|
|
|
|
|
|
waitLock.Lock()
|
2016-08-14 12:57:49 -06:00
|
|
|
return server, pc.LocalAddr().String(), nil
|
2016-04-07 08:03:57 +01:00
|
|
|
}
|