From 2750c5e1e7efb600100aef497f1b11908d4ecb34 Mon Sep 17 00:00:00 2001 From: Tim Hockin Date: Wed, 24 Nov 2021 13:35:27 -0800 Subject: [PATCH] funcr: Fix bug in repeated calls to WithValues When using `RenderValuesHook` we need to save the raw value, not the rendered form. --- funcr/example_test.go | 5 +++-- funcr/funcr.go | 7 ++++--- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/funcr/example_test.go b/funcr/example_test.go index 1e1a2b2..9197a9a 100644 --- a/funcr/example_test.go +++ b/funcr/example_test.go @@ -94,9 +94,10 @@ func ExampleOptions_renderHooks() { RenderValuesHook: valuesAsObject, }) log = log.WithName("MyLogger") - log = log.WithValues("savedKey", "savedValue") + log = log.WithValues("savedKey1", "savedVal1") + log = log.WithValues("savedKey2", "savedVal2") log.Info("the message", "key", "value") - // Output: {"log:logger":"MyLogger","log:level":0,"log:msg":"the message","labels":{"savedKey":"savedValue"},"key":"value"} + // Output: {"log:logger":"MyLogger","log:level":0,"log:msg":"the message","labels":{"savedKey1":"savedVal1","savedKey2":"savedVal2"},"key":"value"} } func ExamplePseudoStruct() { diff --git a/funcr/funcr.go b/funcr/funcr.go index 8ecf434..4727d27 100644 --- a/funcr/funcr.go +++ b/funcr/funcr.go @@ -722,15 +722,16 @@ func (f *Formatter) AddName(name string) { func (f *Formatter) AddValues(kvList []interface{}) { // Three slice args forces a copy. n := len(f.values) - vals := f.values[:n:n] - vals = append(vals, kvList...) + f.values = append(f.values[:n:n], kvList...) + + vals := f.values if hook := f.opts.RenderValuesHook; hook != nil { vals = hook(f.sanitize(vals)) } // Pre-render values, so we don't have to do it on each Info/Error call. buf := bytes.NewBuffer(make([]byte, 0, 1024)) - f.values = f.flatten(buf, vals, false, true) // escape user-provided keys + f.flatten(buf, vals, false, true) // escape user-provided keys f.valuesStr = buf.String() }