From c172fd4f63ed28c5a079db1e1589a8b08f7c75b9 Mon Sep 17 00:00:00 2001 From: Payton Swick Date: Fri, 13 Dec 2024 15:40:40 -0500 Subject: [PATCH] Checkout: Do not log errorMessage in checkout logstash if message is the same (#97477) * Do not log errorMessage in checkout logstash if message is the same * Only log tags once --- client/my-sites/checkout/src/lib/analytics.ts | 25 ++++++++++++++----- 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/client/my-sites/checkout/src/lib/analytics.ts b/client/my-sites/checkout/src/lib/analytics.ts index 6ec9b6ddf20c3d..d96e32b8e5627c 100644 --- a/client/my-sites/checkout/src/lib/analytics.ts +++ b/client/my-sites/checkout/src/lib/analytics.ts @@ -76,7 +76,13 @@ export function logStashLoadErrorEvent( message: additionalData.message ? String( additionalData.message ) : convertErrorToString( error ), - errorMessage: convertErrorToString( error ), + ...( additionalData.message + ? // No need to log the `errorMessage` separately if it's the same as + // the `message` property. + { + errorMessage: convertErrorToString( error ), + } + : {} ), tags: [ 'checkout-error-boundary' ], } ); } @@ -88,15 +94,22 @@ export function logStashEvent( dataForLog: DataForLog, severity: 'error' | 'warning' | 'info' = 'error' ): Promise< void > { + const tags = dataForLog.tags ?? []; + const extra: Record< string, string | string[] > = { + env: config( 'env_id' ), + }; + Object.keys( dataForLog ).forEach( ( key ) => { + if ( key === 'tags' ) { + return; + } + extra[ key ] = dataForLog[ key ]; + } ); return logToLogstash( { feature: 'calypso_client', message, severity: config( 'env_id' ) === 'production' ? severity : 'debug', - extra: { - env: config( 'env_id' ), - ...dataForLog, - }, - tags: dataForLog.tags ?? [], + extra, + tags, } ); }