From 98c28e299087874091437c0db4bcbcf86b30bcf6 Mon Sep 17 00:00:00 2001 From: Patrick Ohly Date: Wed, 3 Jan 2024 15:56:36 +0100 Subject: [PATCH] slog: use main logr package instead of logr/slogr logr v1.4.0 moved the slog support functions in the main package and deprecated slogr. --- klogr_slog.go | 10 +++++----- klogr_slog_test.go | 17 +++++++++-------- textlogger/textlogger_slog.go | 8 ++++---- 3 files changed, 18 insertions(+), 17 deletions(-) diff --git a/klogr_slog.go b/klogr_slog.go index f7bf7403..c77d7baa 100644 --- a/klogr_slog.go +++ b/klogr_slog.go @@ -25,7 +25,7 @@ import ( "strconv" "time" - "github.com/go-logr/logr/slogr" + "github.com/go-logr/logr" "k8s.io/klog/v2/internal/buffer" "k8s.io/klog/v2/internal/serialize" @@ -35,7 +35,7 @@ import ( func (l *klogger) Handle(ctx context.Context, record slog.Record) error { if logging.logger != nil { - if slogSink, ok := logging.logger.GetSink().(slogr.SlogSink); ok { + if slogSink, ok := logging.logger.GetSink().(logr.SlogSink); ok { // Let that logger do the work. return slogSink.Handle(ctx, record) } @@ -77,13 +77,13 @@ func slogOutput(file string, line int, now time.Time, err error, s severity.Seve buffer.PutBuffer(b) } -func (l *klogger) WithAttrs(attrs []slog.Attr) slogr.SlogSink { +func (l *klogger) WithAttrs(attrs []slog.Attr) logr.SlogSink { clone := *l clone.values = serialize.WithValues(l.values, sloghandler.Attrs2KVList(l.groups, attrs)) return &clone } -func (l *klogger) WithGroup(name string) slogr.SlogSink { +func (l *klogger) WithGroup(name string) logr.SlogSink { clone := *l if clone.groups != "" { clone.groups += "." + name @@ -93,4 +93,4 @@ func (l *klogger) WithGroup(name string) slogr.SlogSink { return &clone } -var _ slogr.SlogSink = &klogger{} +var _ logr.SlogSink = &klogger{} diff --git a/klogr_slog_test.go b/klogr_slog_test.go index b6431a71..d112b0fd 100644 --- a/klogr_slog_test.go +++ b/klogr_slog_test.go @@ -27,7 +27,8 @@ import ( "os" "time" - "github.com/go-logr/logr/slogr" + "github.com/go-logr/logr" + "k8s.io/klog/v2" internal "k8s.io/klog/v2/internal/buffer" ) @@ -71,7 +72,7 @@ func ExampleBackground_Slog() { internal.Pid = 123 logrLogger := klog.Background() - slogHandler := slogr.NewSlogHandler(logrLogger) + slogHandler := logr.ToSlogHandler(logrLogger) slogLogger := slog.New(slogHandler) // Note that -vmodule does not work when using the slog API because @@ -107,10 +108,10 @@ func ExampleBackground_Slog() { ) // Output: - // I1224 12:30:40.000000 123 klogr_slog_test.go:80] "A debug message" - // I1224 12:30:40.000000 123 klogr_slog_test.go:82] "An info message" - // W1224 12:30:40.000000 123 klogr_slog_test.go:83] "A warning" - // E1224 12:30:40.000000 123 klogr_slog_test.go:84] "An error" err="fake error" - // I1224 12:30:40.000000 123 klogr_slog_test.go:87] "Grouping" top.sub={"str":"abc","bool":true,"bottom":{"coordinates":{"X":-1,"Y":-2}}} top.duration="1s" top.pi=3.12 top.e=2.71 top.moreCoordinates={"X":100,"Y":200} - // I1224 12:30:40.000000 123 klogr_slog_test.go:103] "slog values" variables={"a":1,"b":2} duration="1s" coordinates={"X":100,"Y":200} + // I1224 12:30:40.000000 123 klogr_slog_test.go:81] "A debug message" + // I1224 12:30:40.000000 123 klogr_slog_test.go:83] "An info message" + // W1224 12:30:40.000000 123 klogr_slog_test.go:84] "A warning" + // E1224 12:30:40.000000 123 klogr_slog_test.go:85] "An error" err="fake error" + // I1224 12:30:40.000000 123 klogr_slog_test.go:88] "Grouping" top.sub={"str":"abc","bool":true,"bottom":{"coordinates":{"X":-1,"Y":-2}}} top.duration="1s" top.pi=3.12 top.e=2.71 top.moreCoordinates={"X":100,"Y":200} + // I1224 12:30:40.000000 123 klogr_slog_test.go:104] "slog values" variables={"a":1,"b":2} duration="1s" coordinates={"X":100,"Y":200} } diff --git a/textlogger/textlogger_slog.go b/textlogger/textlogger_slog.go index af0fab00..c888ef8a 100644 --- a/textlogger/textlogger_slog.go +++ b/textlogger/textlogger_slog.go @@ -23,7 +23,7 @@ import ( "context" "log/slog" - "github.com/go-logr/logr/slogr" + "github.com/go-logr/logr" "k8s.io/klog/v2/internal/serialize" "k8s.io/klog/v2/internal/sloghandler" @@ -33,13 +33,13 @@ func (l *tlogger) Handle(ctx context.Context, record slog.Record) error { return sloghandler.Handle(ctx, record, l.groups, l.printWithInfos) } -func (l *tlogger) WithAttrs(attrs []slog.Attr) slogr.SlogSink { +func (l *tlogger) WithAttrs(attrs []slog.Attr) logr.SlogSink { clone := *l clone.values = serialize.WithValues(l.values, sloghandler.Attrs2KVList(l.groups, attrs)) return &clone } -func (l *tlogger) WithGroup(name string) slogr.SlogSink { +func (l *tlogger) WithGroup(name string) logr.SlogSink { clone := *l if clone.groups != "" { clone.groups += "." + name @@ -49,4 +49,4 @@ func (l *tlogger) WithGroup(name string) slogr.SlogSink { return &clone } -var _ slogr.SlogSink = &tlogger{} +var _ logr.SlogSink = &tlogger{}