2019-05-12 04:15:21 -04:00
|
|
|
package dns
|
|
|
|
|
2022-02-05 10:53:49 +10:30
|
|
|
import (
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
)
|
2019-05-12 04:15:21 -04:00
|
|
|
|
|
|
|
var (
|
|
|
|
tsigSecret = map[string]string{"axfr.": "so6ZGir4GPAqINNh9U5c3A=="}
|
|
|
|
xfrSoa = testRR(`miek.nl. 0 IN SOA linode.atoom.net. miek.miek.nl. 2009032802 21600 7200 604800 3600`)
|
|
|
|
xfrA = testRR(`x.miek.nl. 1792 IN A 10.0.0.1`)
|
|
|
|
xfrMX = testRR(`miek.nl. 1800 IN MX 1 x.miek.nl.`)
|
|
|
|
xfrTestData = []RR{xfrSoa, xfrA, xfrMX, xfrSoa}
|
|
|
|
)
|
|
|
|
|
|
|
|
func InvalidXfrServer(w ResponseWriter, req *Msg) {
|
|
|
|
ch := make(chan *Envelope)
|
|
|
|
tr := new(Transfer)
|
|
|
|
|
|
|
|
go tr.Out(w, req, ch)
|
|
|
|
ch <- &Envelope{RR: []RR{}}
|
|
|
|
close(ch)
|
|
|
|
w.Hijack()
|
|
|
|
}
|
|
|
|
|
|
|
|
func SingleEnvelopeXfrServer(w ResponseWriter, req *Msg) {
|
|
|
|
ch := make(chan *Envelope)
|
|
|
|
tr := new(Transfer)
|
|
|
|
|
|
|
|
go tr.Out(w, req, ch)
|
|
|
|
ch <- &Envelope{RR: xfrTestData}
|
|
|
|
close(ch)
|
|
|
|
w.Hijack()
|
|
|
|
}
|
|
|
|
|
|
|
|
func MultipleEnvelopeXfrServer(w ResponseWriter, req *Msg) {
|
|
|
|
ch := make(chan *Envelope)
|
|
|
|
tr := new(Transfer)
|
|
|
|
|
|
|
|
go tr.Out(w, req, ch)
|
|
|
|
|
|
|
|
for _, rr := range xfrTestData {
|
|
|
|
ch <- &Envelope{RR: []RR{rr}}
|
|
|
|
}
|
|
|
|
close(ch)
|
|
|
|
w.Hijack()
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestInvalidXfr(t *testing.T) {
|
|
|
|
HandleFunc("miek.nl.", InvalidXfrServer)
|
|
|
|
defer HandleRemove("miek.nl.")
|
|
|
|
|
2020-10-25 02:23:01 +10:30
|
|
|
s, addrstr, _, err := RunLocalTCPServer(":0")
|
2019-05-12 04:15:21 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("unable to run test server: %s", err)
|
|
|
|
}
|
|
|
|
defer s.Shutdown()
|
|
|
|
|
|
|
|
tr := new(Transfer)
|
|
|
|
m := new(Msg)
|
|
|
|
m.SetAxfr("miek.nl.")
|
|
|
|
|
|
|
|
c, err := tr.In(m, addrstr)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal("failed to zone transfer in", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
for msg := range c {
|
|
|
|
if msg.Error == nil {
|
|
|
|
t.Fatal("failed to catch 'no SOA' error")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestSingleEnvelopeXfr(t *testing.T) {
|
|
|
|
HandleFunc("miek.nl.", SingleEnvelopeXfrServer)
|
|
|
|
defer HandleRemove("miek.nl.")
|
|
|
|
|
2020-10-25 02:23:01 +10:30
|
|
|
s, addrstr, _, err := RunLocalTCPServer(":0", func(srv *Server) {
|
|
|
|
srv.TsigSecret = tsigSecret
|
|
|
|
})
|
2019-05-12 04:15:21 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("unable to run test server: %s", err)
|
|
|
|
}
|
|
|
|
defer s.Shutdown()
|
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
axfrTestingSuite(t, addrstr)
|
2019-05-12 04:15:21 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
func TestMultiEnvelopeXfr(t *testing.T) {
|
|
|
|
HandleFunc("miek.nl.", MultipleEnvelopeXfrServer)
|
|
|
|
defer HandleRemove("miek.nl.")
|
|
|
|
|
2020-10-25 02:23:01 +10:30
|
|
|
s, addrstr, _, err := RunLocalTCPServer(":0", func(srv *Server) {
|
|
|
|
srv.TsigSecret = tsigSecret
|
|
|
|
})
|
2019-05-12 04:15:21 -04:00
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("unable to run test server: %s", err)
|
|
|
|
}
|
|
|
|
defer s.Shutdown()
|
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
axfrTestingSuite(t, addrstr)
|
2019-05-12 04:15:21 -04:00
|
|
|
}
|
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
func axfrTestingSuite(t *testing.T, addrstr string) {
|
|
|
|
tr := new(Transfer)
|
|
|
|
m := new(Msg)
|
|
|
|
m.SetAxfr("miek.nl.")
|
2019-05-12 04:15:21 -04:00
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
c, err := tr.In(m, addrstr)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal("failed to zone transfer in", err)
|
|
|
|
}
|
2019-05-12 04:15:21 -04:00
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
var records []RR
|
|
|
|
for msg := range c {
|
|
|
|
if msg.Error != nil {
|
|
|
|
t.Fatal(msg.Error)
|
2019-05-12 04:15:21 -04:00
|
|
|
}
|
2020-10-24 22:28:44 +10:30
|
|
|
records = append(records, msg.RR...)
|
|
|
|
}
|
2019-05-12 04:15:21 -04:00
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
if len(records) != len(xfrTestData) {
|
|
|
|
t.Fatalf("bad axfr: expected %v, got %v", records, xfrTestData)
|
|
|
|
}
|
2019-05-12 04:15:21 -04:00
|
|
|
|
2020-10-24 22:28:44 +10:30
|
|
|
for i, rr := range records {
|
|
|
|
if !IsDuplicate(rr, xfrTestData[i]) {
|
|
|
|
t.Fatalf("bad axfr: expected %v, got %v", records, xfrTestData)
|
2019-05-12 04:15:21 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2022-02-05 10:53:49 +10:30
|
|
|
|
|
|
|
func axfrTestingSuiteWithCustomTsig(t *testing.T, addrstr string, provider TsigProvider) {
|
|
|
|
tr := new(Transfer)
|
|
|
|
m := new(Msg)
|
|
|
|
var err error
|
|
|
|
tr.Conn, err = Dial("tcp", addrstr)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal("failed to dial", err)
|
|
|
|
}
|
|
|
|
tr.TsigProvider = provider
|
|
|
|
m.SetAxfr("miek.nl.")
|
|
|
|
m.SetTsig("axfr.", HmacSHA256, 300, time.Now().Unix())
|
|
|
|
|
|
|
|
c, err := tr.In(m, addrstr)
|
|
|
|
if err != nil {
|
|
|
|
t.Fatal("failed to zone transfer in", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var records []RR
|
|
|
|
for msg := range c {
|
|
|
|
if msg.Error != nil {
|
|
|
|
t.Fatal(msg.Error)
|
|
|
|
}
|
|
|
|
records = append(records, msg.RR...)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(records) != len(xfrTestData) {
|
|
|
|
t.Fatalf("bad axfr: expected %v, got %v", records, xfrTestData)
|
|
|
|
}
|
|
|
|
|
|
|
|
for i, rr := range records {
|
|
|
|
if !IsDuplicate(rr, xfrTestData[i]) {
|
|
|
|
t.Errorf("bad axfr: expected %v, got %v", records, xfrTestData)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCustomTsigProvider(t *testing.T) {
|
|
|
|
HandleFunc("miek.nl.", SingleEnvelopeXfrServer)
|
|
|
|
defer HandleRemove("miek.nl.")
|
|
|
|
|
|
|
|
s, addrstr, _, err := RunLocalTCPServer(":0", func(srv *Server) {
|
|
|
|
srv.TsigProvider = tsigSecretProvider(tsigSecret)
|
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
t.Fatalf("unable to run test server: %s", err)
|
|
|
|
}
|
|
|
|
defer s.Shutdown()
|
|
|
|
|
|
|
|
axfrTestingSuiteWithCustomTsig(t, addrstr, tsigSecretProvider(tsigSecret))
|
|
|
|
}
|