11 func TestHandlers(t *testing.T) {
12 ctx := context.Background()
13 r := slog.NewRecord(testTime, slog.LevelInfo, testMessage, 0)
14 r.AddAttrs(testAttrs...)
15 t.Run("text", func(t *testing.T) {
17 h := newFastTextHandler(&b)
18 if err := h.Handle(ctx, r); err != nil {
23 t.Errorf("\ngot %q\nwant %q", got, wantText)
26 t.Run("async", func(t *testing.T) {
27 h := newAsyncHandler()
28 if err := h.Handle(ctx, r); err != nil {
31 got := h.ringBuffer[0]
32 if !got.Time.Equal(r.Time) || !slices.EqualFunc(attrSlice(got), attrSlice(r), slog.Attr.Equal) {
33 t.Errorf("got %+v, want %+v", got, r)
38 func attrSlice(r slog.Record) []slog.Attr {
40 r.Attrs(func(a slog.Attr) bool { as = append(as, a); return true })