plugin/trace: fix rcode tag in case of no response (#4742)

Signed-off-by: Ondrej Benkovsky <ondrej.benkovsky@wandera.com>
This commit is contained in:
Ondřej Benkovský
2021-07-10 07:34:53 +02:00
committed by GitHub
parent 6efda5293e
commit d17e50afc7
2 changed files with 25 additions and 8 deletions

View File

@@ -149,7 +149,14 @@ func (t *trace) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg)
span.SetTag(t.tagSet.Type, req.Type()) span.SetTag(t.tagSet.Type, req.Type())
span.SetTag(t.tagSet.Proto, req.Proto()) span.SetTag(t.tagSet.Proto, req.Proto())
span.SetTag(t.tagSet.Remote, req.IP()) span.SetTag(t.tagSet.Remote, req.IP())
span.SetTag(t.tagSet.Rcode, rcode.ToString(rw.Rcode)) rc := rw.Rcode
if !plugin.ClientWrite(status) {
// when no response was written, fallback to status returned from next plugin as this status
// is actually used as rcode of DNS response
// see https://github.com/coredns/coredns/blob/master/core/dnsserver/server.go#L318
rc = status
}
span.SetTag(t.tagSet.Rcode, rcode.ToString(rc))
if err != nil { if err != nil {
otext.Error.Set(span, true) otext.Error.Set(span, true)
span.LogFields(otlog.Event("error"), otlog.Error(err)) span.LogFields(otlog.Event("error"), otlog.Error(err))

View File

@@ -6,6 +6,7 @@ import (
"testing" "testing"
"github.com/coredns/caddy" "github.com/coredns/caddy"
"github.com/coredns/coredns/plugin"
"github.com/coredns/coredns/plugin/pkg/dnstest" "github.com/coredns/coredns/plugin/pkg/dnstest"
"github.com/coredns/coredns/plugin/pkg/rcode" "github.com/coredns/coredns/plugin/pkg/rcode"
"github.com/coredns/coredns/plugin/test" "github.com/coredns/coredns/plugin/test"
@@ -43,23 +44,33 @@ func TestTrace(t *testing.T) {
cases := []struct { cases := []struct {
name string name string
rcode int rcode int
status int
question *dns.Msg question *dns.Msg
server string
err error err error
}{ }{
{ {
name: "NXDOMAIN", name: "NXDOMAIN",
rcode: dns.RcodeNameError, rcode: dns.RcodeNameError,
status: dns.RcodeSuccess,
question: new(dns.Msg).SetQuestion("example.org.", dns.TypeA), question: new(dns.Msg).SetQuestion("example.org.", dns.TypeA),
}, },
{ {
name: "NOERROR", name: "NOERROR",
rcode: dns.RcodeSuccess, rcode: dns.RcodeSuccess,
status: dns.RcodeSuccess,
question: new(dns.Msg).SetQuestion("example.net.", dns.TypeCNAME), question: new(dns.Msg).SetQuestion("example.net.", dns.TypeCNAME),
}, },
{ {
name: "SERVFAIL", name: "SERVFAIL",
rcode: dns.RcodeServerFailure, rcode: dns.RcodeServerFailure,
status: dns.RcodeSuccess,
question: new(dns.Msg).SetQuestion("example.net.", dns.TypeA),
err: errors.New("test error"),
},
{
name: "No response written",
rcode: dns.RcodeServerFailure,
status: dns.RcodeServerFailure,
question: new(dns.Msg).SetQuestion("example.net.", dns.TypeA), question: new(dns.Msg).SetQuestion("example.net.", dns.TypeA),
err: errors.New("test error"), err: errors.New("test error"),
}, },
@@ -71,13 +82,12 @@ func TestTrace(t *testing.T) {
m := mocktracer.New() m := mocktracer.New()
tr := &trace{ tr := &trace{
Next: test.HandlerFunc(func(_ context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) { Next: test.HandlerFunc(func(_ context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
m := new(dns.Msg) if plugin.ClientWrite(tc.status) {
m.SetRcode(r, tc.rcode) m := new(dns.Msg)
w.WriteMsg(m) m.SetRcode(r, tc.rcode)
if tc.err != nil { w.WriteMsg(m)
return tc.rcode, tc.err
} }
return tc.rcode, nil return tc.status, tc.err
}), }),
every: 1, every: 1,
tracer: m, tracer: m,