| 121 | } |
| 122 | |
| 123 | func TestContext_ErrWithStackMarshalerInterface(t *testing.T) { |
| 124 | // Save original |
| 125 | original := ErrorStackMarshaler |
| 126 | defer func() { ErrorStackMarshaler = original }() |
| 127 | |
| 128 | // Set a mock marshaler that returns an int |
| 129 | ErrorStackMarshaler = func(err error) interface{} { |
| 130 | return 42 |
| 131 | } |
| 132 | |
| 133 | var buf bytes.Buffer |
| 134 | log := New(&buf).With().Stack().Err(errors.New("test error")).Logger() |
| 135 | |
| 136 | log.Info().Msg("test message") |
| 137 | |
| 138 | got := decodeIfBinaryToString(buf.Bytes()) |
| 139 | want := `{"level":"info","stack":42,"error":"test error","message":"test message"}` + "\n" |
| 140 | if got != want { |
| 141 | t.Errorf("Context.Err() with stack marshaler interface = %q, want %q", got, want) |
| 142 | } |
| 143 | } |