aboutsummaryrefslogtreecommitdiff
path: root/middleware/dnstap/handler_test.go
diff options
context:
space:
mode:
authorGravatar varyoo <varyoo@users.noreply.github.com> 2017-07-24 23:12:50 +0200
committerGravatar Miek Gieben <miek@miek.nl> 2017-07-24 14:12:50 -0700
commit1b7492be6e07f4b8306c0b4a56d79f37485ae61c (patch)
tree02510da5a7cf228821373a8090bac29055764aba /middleware/dnstap/handler_test.go
parentf33b02689c564c1de8774f7f99d2400231a76069 (diff)
downloadcoredns-1b7492be6e07f4b8306c0b4a56d79f37485ae61c.tar.gz
coredns-1b7492be6e07f4b8306c0b4a56d79f37485ae61c.tar.zst
coredns-1b7492be6e07f4b8306c0b4a56d79f37485ae61c.zip
WIP: middleware/dnstap (#711)
middleware/dnstap add
Diffstat (limited to 'middleware/dnstap/handler_test.go')
-rw-r--r--middleware/dnstap/handler_test.go65
1 files changed, 65 insertions, 0 deletions
diff --git a/middleware/dnstap/handler_test.go b/middleware/dnstap/handler_test.go
new file mode 100644
index 000000000..dfdde582d
--- /dev/null
+++ b/middleware/dnstap/handler_test.go
@@ -0,0 +1,65 @@
+package dnstap
+
+import (
+ "errors"
+ "fmt"
+ "testing"
+
+ "github.com/coredns/coredns/middleware/dnstap/test"
+ mwtest "github.com/coredns/coredns/middleware/test"
+
+ tap "github.com/dnstap/golang-dnstap"
+ "github.com/golang/protobuf/proto"
+ "github.com/miekg/dns"
+ "golang.org/x/net/context"
+)
+
+func testCase(t *testing.T, tapq, tapr *tap.Message, q, r *dns.Msg) {
+ w := writer{}
+ w.queue = append(w.queue, tapq, tapr)
+ h := Dnstap{
+ Next: mwtest.HandlerFunc(func(_ context.Context,
+ w dns.ResponseWriter, _ *dns.Msg) (int, error) {
+
+ return 0, w.WriteMsg(r)
+ }),
+ Out: &w,
+ Pack: false,
+ }
+ _, err := h.ServeDNS(context.TODO(), &mwtest.ResponseWriter{}, q)
+ if err != nil {
+ t.Fatal(err)
+ }
+}
+
+type writer struct {
+ queue []*tap.Message
+}
+
+func (w *writer) Write(b []byte) (int, error) {
+ e := tap.Dnstap{}
+ if err := proto.Unmarshal(b, &e); err != nil {
+ return 0, err
+ }
+ if len(w.queue) == 0 {
+ return 0, errors.New("message not expected")
+ }
+ if !test.MsgEqual(w.queue[0], e.Message) {
+ return 0, fmt.Errorf("want: %v, have: %v", w.queue[0], e.Message)
+ }
+ w.queue = w.queue[1:]
+ return len(b), nil
+}
+
+func TestDnstap(t *testing.T) {
+ q := mwtest.Case{Qname: "example.org", Qtype: dns.TypeA}.Msg()
+ r := mwtest.Case{
+ Qname: "example.org.", Qtype: dns.TypeA,
+ Answer: []dns.RR{
+ mwtest.A("example.org. 3600 IN A 10.0.0.1"),
+ },
+ }.Msg()
+ tapq := test.TestingData().ToClientQuery()
+ tapr := test.TestingData().ToClientResponse()
+ testCase(t, tapq, tapr, q, r)
+}