99 lines
2.0 KiB
Go
99 lines
2.0 KiB
Go
package dns
|
|
|
|
import (
|
|
"testing"
|
|
"time"
|
|
)
|
|
|
|
func TestClientSync(t *testing.T) {
|
|
m := new(Msg)
|
|
m.SetQuestion("miek.nl", TypeSOA)
|
|
|
|
c := NewClient()
|
|
r := c.Exchange(m, "85.223.71.124:53")
|
|
|
|
if r != nil && r.Rcode != RcodeSuccess {
|
|
t.Log("Failed to get an valid answer")
|
|
t.Fail()
|
|
t.Logf("%v\n", r)
|
|
}
|
|
}
|
|
|
|
func helloMiek(w RequestWriter, r *Msg) {
|
|
w.Send(r)
|
|
reply, _ := w.Receive()
|
|
w.Write(reply)
|
|
}
|
|
|
|
func TestClientASync(t *testing.T) {
|
|
HandleQueryFunc("miek.nl", helloMiek) // All queries for miek.nl will be handled by HelloMiek
|
|
ListenAndQuery(nil, nil) // Detect if this isn't running
|
|
|
|
m := new(Msg)
|
|
m.SetQuestion("miek.nl", TypeSOA)
|
|
|
|
c := NewClient()
|
|
c.Do(m, "85.223.71.124:53")
|
|
|
|
forever:
|
|
for {
|
|
select {
|
|
case n := <-DefaultReplyChan:
|
|
if n[1] != nil && n[1].Rcode != RcodeSuccess {
|
|
t.Log("Failed to get an valid answer")
|
|
t.Fail()
|
|
t.Logf("%v\n", n[1])
|
|
}
|
|
break forever
|
|
}
|
|
}
|
|
}
|
|
|
|
func TestClientEDNS0(t *testing.T) {
|
|
m := new(Msg)
|
|
m.SetQuestion("miek.nl", TypeDNSKEY)
|
|
|
|
edns := new(RR_OPT)
|
|
edns.Hdr.Name = "." // must . be for edns
|
|
edns.Hdr.Rrtype = TypeOPT
|
|
// You can handle an OTP RR as any other, but there
|
|
// are some convience functions
|
|
edns.SetUDPSize(2048)
|
|
edns.SetDo()
|
|
edns.Option = make([]Option, 1)
|
|
edns.SetNsid("") // Empty to request it
|
|
|
|
m.Extra = make([]RR, 1)
|
|
m.Extra[0] = edns
|
|
|
|
c := NewClient()
|
|
r := c.Exchange(m, "85.223.71.124:53")
|
|
|
|
if r != nil && r.Rcode != RcodeSuccess {
|
|
t.Log("Failed to get an valid answer")
|
|
t.Fail()
|
|
t.Logf("%v\n", r)
|
|
}
|
|
}
|
|
|
|
func TestClientTsigAXFR(t *testing.T) {
|
|
m := new(Msg)
|
|
m.SetAxfr("miek.nl")
|
|
|
|
m.SetTsig("axfr", HmacMD5, 300, uint64(time.Seconds()))
|
|
secrets := make(map[string]string)
|
|
secrets["axfr"] = "so6ZGir4GPAqINNh9U5c3A=="
|
|
|
|
c := NewClient()
|
|
c.Net = "tcp"
|
|
c.TsigSecret = secrets
|
|
|
|
c.XfrReceive(m, "85.223.71.124:53")
|
|
/*
|
|
if err != nil {
|
|
t.Log("%s\n", err.String())
|
|
t.Fail()
|
|
}
|
|
*/
|
|
}
|