diff options
author | 2017-04-16 07:49:13 +0100 | |
---|---|---|
committer | 2017-04-16 07:49:13 +0100 | |
commit | 73397e4667fbb070b29888900dc1c1d91a21fa51 (patch) | |
tree | 7d8be8a39394e7bdcec8e178a60660b8c4f76144 /middleware/erratic/erratic_test.go | |
parent | a83d97a5c446481da3b9efc8f017e6a6ea34b7b0 (diff) | |
download | coredns-73397e4667fbb070b29888900dc1c1d91a21fa51.tar.gz coredns-73397e4667fbb070b29888900dc1c1d91a21fa51.tar.zst coredns-73397e4667fbb070b29888900dc1c1d91a21fa51.zip |
Tc bits (#617)
* middleware/erratic: allow TC bit to be set
Add `truncate` as an option.
Fixes #593
Diffstat (limited to 'middleware/erratic/erratic_test.go')
-rw-r--r-- | middleware/erratic/erratic_test.go | 36 |
1 files changed, 35 insertions, 1 deletions
diff --git a/middleware/erratic/erratic_test.go b/middleware/erratic/erratic_test.go index c99135bbd..4b54e0c12 100644 --- a/middleware/erratic/erratic_test.go +++ b/middleware/erratic/erratic_test.go @@ -39,7 +39,41 @@ func TestErraticDrop(t *testing.T) { } if tc.drop && rec.Msg != nil { - t.Errorf("Test %d: Expected dropped packet, but got %q", i, rec.Msg.Question[0].Name) + t.Errorf("Test %d: Expected dropped message, but got %q", i, rec.Msg.Question[0].Name) + } + } +} + +func TestErraticTruncate(t *testing.T) { + e := &Erratic{truncate: 2} // 50% drops + + tests := []struct { + expectedCode int + expectedErr error + truncate bool + }{ + {expectedCode: dns.RcodeSuccess, expectedErr: nil, truncate: true}, + {expectedCode: dns.RcodeSuccess, expectedErr: nil, truncate: false}, + } + + ctx := context.TODO() + + for i, tc := range tests { + req := new(dns.Msg) + req.SetQuestion("example.org.", dns.TypeA) + + rec := dnsrecorder.New(&test.ResponseWriter{}) + code, err := e.ServeDNS(ctx, rec, req) + + if err != tc.expectedErr { + t.Errorf("Test %d: Expected error %q, but got %q", i, tc.expectedErr, err) + } + if code != int(tc.expectedCode) { + t.Errorf("Test %d: Expected status code %d, but got %d", i, tc.expectedCode, code) + } + + if tc.truncate && !rec.Msg.Truncated { + t.Errorf("Test %d: Expected truncated message, but got %q", i, rec.Msg.Question[0].Name) } } } |