Documentation ¶
Overview ¶
Package testutil implements common testing utilities.
Index ¶
- func DNSQuery(srv, addr string, qtype uint16) (*dns.Msg, dns.RR, error)
- func GetFreePort() string
- func MakeStaticHandler(tb testing.TB, answer string) func(dns.ResponseWriter, *dns.Msg)
- func NewRR(tb testing.TB, s string) dns.RR
- func ServeTestDNSServer(addr string, handler func(dns.ResponseWriter, *dns.Msg))
- func WaitForDNSServer(addr string) error
- func WaitForHTTPServer(addr string) error
- type TestResolver
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func GetFreePort ¶
func GetFreePort() string
GetFreePort returns a free TCP port. This is hacky and not race-free, but it works well enough for testing purposes.
func MakeStaticHandler ¶
MakeStaticHandler for the DNS server. The given answer must be a valid zone.
func ServeTestDNSServer ¶
func ServeTestDNSServer(addr string, handler func(dns.ResponseWriter, *dns.Msg))
ServeTestDNSServer starts the fake DNS server.
func WaitForDNSServer ¶
WaitForDNSServer waits 5 seconds for a DNS server to start, and returns an error if it fails to do so. It does this by repeatedly querying the DNS server until it either replies or times out. Note we do not do any validation of the reply.
func WaitForHTTPServer ¶
WaitForHTTPServer waits 5 seconds for an HTTP server to start, and returns an error if it fails to do so. It does this by repeatedly querying the server until it either replies or times out.
Types ¶
type TestResolver ¶
type TestResolver struct { // Has this resolver been initialized? Initialized bool // Maintain() sends a value over this channel. MaintainC chan bool // The last query we've seen. LastQuery *dns.Msg // What we will respond to queries. Response *dns.Msg RespError error }
TestResolver is a dnsserver.Resolver implementation for testing, so we can control its responses during tests.
func NewTestResolver ¶
func NewTestResolver() *TestResolver
NewTestResolver creates a new TestResolver with minimal initialization.