Make sure logger serializes errors (#2001)

zio/stable
Eric Bailey 2023-11-27 12:28:21 -06:00 committed by GitHub
parent 6758755316
commit 1dc017367e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 37 additions and 4 deletions

View File

@ -222,6 +222,26 @@ describe('general functionality', () => {
}) })
}) })
test('sentryTransport serializes errors', () => {
const message = 'message'
const timestamp = Date.now()
const sentryTimestamp = timestamp / 1000
sentryTransport(
LogLevel.Debug,
message,
{error: new Error('foo')},
timestamp,
)
expect(Sentry.addBreadcrumb).toHaveBeenCalledWith({
message,
data: {error: 'Error: foo'},
type: 'default',
level: LogLevel.Debug,
timestamp: sentryTimestamp,
})
})
test('add/remove transport', () => { test('add/remove transport', () => {
const timestamp = Date.now() const timestamp = Date.now()
const logger = new Logger({enabled: true}) const logger = new Logger({enabled: true})

View File

@ -90,6 +90,16 @@ const enabledLogLevels: {
[LogLevel.Error]: [LogLevel.Error], [LogLevel.Error]: [LogLevel.Error],
} }
export function prepareMetadata(metadata: Metadata): Metadata {
return Object.keys(metadata).reduce((acc, key) => {
let value = metadata[key]
if (value instanceof Error) {
value = value.toString()
}
return {...acc, [key]: value}
}, {})
}
/** /**
* Used in dev mode to nicely log to the console * Used in dev mode to nicely log to the console
*/ */
@ -100,7 +110,8 @@ export const consoleTransport: Transport = (
timestamp, timestamp,
) => { ) => {
const extra = Object.keys(metadata).length const extra = Object.keys(metadata).length
? ' ' + JSON.stringify(metadata, null, ' ') ? // don't prepareMetadata here, in dev we want the stack trace
' ' + JSON.stringify(metadata, null, ' ')
: '' : ''
const log = { const log = {
[LogLevel.Debug]: console.debug, [LogLevel.Debug]: console.debug,
@ -119,6 +130,8 @@ export const sentryTransport: Transport = (
{type, tags, ...metadata}, {type, tags, ...metadata},
timestamp, timestamp,
) => { ) => {
const meta = prepareMetadata(metadata)
/** /**
* If a string, report a breadcrumb * If a string, report a breadcrumb
*/ */
@ -135,7 +148,7 @@ export const sentryTransport: Transport = (
Sentry.addBreadcrumb({ Sentry.addBreadcrumb({
message, message,
data: metadata, data: meta,
type: type || 'default', type: type || 'default',
level: severity, level: severity,
timestamp: timestamp / 1000, // Sentry expects seconds timestamp: timestamp / 1000, // Sentry expects seconds
@ -155,7 +168,7 @@ export const sentryTransport: Transport = (
Sentry.captureMessage(message, { Sentry.captureMessage(message, {
level: messageLevel, level: messageLevel,
tags, tags,
extra: metadata, extra: meta,
}) })
} }
} else { } else {
@ -164,7 +177,7 @@ export const sentryTransport: Transport = (
*/ */
Sentry.captureException(message, { Sentry.captureException(message, {
tags, tags,
extra: metadata, extra: meta,
}) })
} }
} }