| 104 | } |
| 105 | |
| 106 | func TestHookEntryIsPristine(t *testing.T) { |
| 107 | l := New() |
| 108 | b := &bytes.Buffer{} |
| 109 | l.Formatter = &JSONFormatter{} |
| 110 | l.Out = b |
| 111 | l.AddHook(&SingleLevelModifyHook{}) |
| 112 | |
| 113 | l.Error("error message") |
| 114 | data := map[string]string{} |
| 115 | err := json.Unmarshal(b.Bytes(), &data) |
| 116 | require.NoError(t, err) |
| 117 | _, ok := data["wow"] |
| 118 | require.False(t, ok) |
| 119 | b.Reset() |
| 120 | |
| 121 | l.Info("error message") |
| 122 | data = map[string]string{} |
| 123 | err = json.Unmarshal(b.Bytes(), &data) |
| 124 | require.NoError(t, err) |
| 125 | _, ok = data["wow"] |
| 126 | require.True(t, ok) |
| 127 | b.Reset() |
| 128 | |
| 129 | l.Error("error message") |
| 130 | data = map[string]string{} |
| 131 | err = json.Unmarshal(b.Bytes(), &data) |
| 132 | require.NoError(t, err) |
| 133 | _, ok = data["wow"] |
| 134 | require.False(t, ok) |
| 135 | b.Reset() |
| 136 | } |
| 137 | |
| 138 | type ErrorHook struct { |
| 139 | Fired bool |