From f6d4e205f306f883cce739a61efbdd6815ba5f43 Mon Sep 17 00:00:00 2001 From: Semyon Krestyaninov <ensiouel@gmail.com> Date: Mon, 26 Feb 2024 20:34:56 +0300 Subject: [PATCH] fix --- zap/filter_core.go | 2 +- zap/filter_core_test.go | 11 +++++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/zap/filter_core.go b/zap/filter_core.go index 7e99d942..dee17ba5 100644 --- a/zap/filter_core.go +++ b/zap/filter_core.go @@ -78,7 +78,7 @@ func WithFilters(core zapcore.Core, filters ...FilterFunc) zapcore.Core { func (core *filterCore) With(fields []zapcore.Field) zapcore.Core { return &filterCore{ - Core: core.Core.With(fields), + Core: core.Core, filters: core.filters, fields: append(core.fields, fields...), } diff --git a/zap/filter_core_test.go b/zap/filter_core_test.go index 21c906f2..3f25a3f9 100644 --- a/zap/filter_core_test.go +++ b/zap/filter_core_test.go @@ -9,6 +9,17 @@ import ( "go.uber.org/zap/zaptest/observer" ) +func TestFilterCore_With(t *testing.T) { + core, logs := observer.New(zapcore.InfoLevel) + core = WithFilters(core) + + err := core.With([]zapcore.Field{zap.String("k", "v")}).Write(zapcore.Entry{Message: "msg"}, nil) + require.NoError(t, err) + + require.Len(t, logs.All(), 1) + require.Len(t, logs.All()[0].Context, 1) +} + func TestFilterCore_Write(t *testing.T) { core, logs := observer.New(zapcore.InfoLevel) core = WithFilters(core, ContainsField(zap.Bool("check", true))) -- GitLab