From 2e133538121c777e5b22e138dbeaf1c12cbbdea3 Mon Sep 17 00:00:00 2001 From: Tyler Yahn Date: Tue, 12 Mar 2024 10:54:25 -0700 Subject: [PATCH] Add concurrency test --- bridges/sloghandler/handler_test.go | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/bridges/sloghandler/handler_test.go b/bridges/sloghandler/handler_test.go index 7c9e56dc042..ddac689957c 100644 --- a/bridges/sloghandler/handler_test.go +++ b/bridges/sloghandler/handler_test.go @@ -13,6 +13,7 @@ import ( "log/slog" "reflect" "runtime" + "sync" "testing" "testing/slogtest" "time" @@ -387,6 +388,31 @@ func value2Result(v log.Value) any { return nil } +func TestConcurrentSafety(t *testing.T) { + lp := noop.NewLoggerProvider() + h := sloghandler.New(lp) + + const goroutineN = 10 + + var wg sync.WaitGroup + wg.Add(goroutineN) + + for i := 0; i < goroutineN; i++ { + go func() { + defer wg.Done() + + _ = h.Enabled(context.Background(), slog.LevelDebug) + + r := slog.NewRecord(time.Now(), slog.LevelDebug, "msg", 0) + _ = h.Handle(context.Background(), r) + + _ = h.WithAttrs([]slog.Attr{slog.Any("key", nil)}) + _ = h.WithGroup("name") + }() + } + wg.Wait() +} + func BenchmarkHandler(b *testing.B) { var ( h slog.Handler