From 280a49e4ef208f7b1256eb32d8ae3d9df0e329b1 Mon Sep 17 00:00:00 2001 From: Luca Forstner Date: Tue, 7 May 2024 16:46:57 +0200 Subject: [PATCH] fix(browser/v7): Continuously record CLS (#11935) --- .../opentelemetry-node/test/spanprocessor.test.ts | 6 +++--- .../tracing-internal/src/browser/instrument.ts | 15 +++++++++------ .../src/browser/web-vitals/getCLS.ts | 7 +++++-- 3 files changed, 17 insertions(+), 11 deletions(-) diff --git a/packages/opentelemetry-node/test/spanprocessor.test.ts b/packages/opentelemetry-node/test/spanprocessor.test.ts index 67d70b895037..9eee6b1c7e05 100644 --- a/packages/opentelemetry-node/test/spanprocessor.test.ts +++ b/packages/opentelemetry-node/test/spanprocessor.test.ts @@ -629,7 +629,7 @@ describe('SentrySpanProcessor', () => { expect(description).toBe('GET /my/route/{id}'); expect(data).toEqual({ - 'http.method': 'GET', + 'http.request.method': 'GET', 'http.route': '/my/route/{id}', 'http.target': '/my/route/123', 'http.url': 'http://example.com/my/route/123', @@ -661,7 +661,7 @@ describe('SentrySpanProcessor', () => { expect(description).toBe('GET http://example.com/my/route/123'); expect(data).toEqual({ - 'http.method': 'GET', + 'http.request.method': 'GET', 'http.target': '/my/route/123', 'http.url': 'http://example.com/my/route/123', 'otel.kind': 'INTERNAL', @@ -693,7 +693,7 @@ describe('SentrySpanProcessor', () => { expect(description).toBe('GET http://example.com/my/route/123'); expect(data).toEqual({ - 'http.method': 'GET', + 'http.request.method': 'GET', 'http.target': '/my/route/123', 'http.url': 'http://example.com/my/route/123?what=123#myHash', 'otel.kind': 'INTERNAL', diff --git a/packages/tracing-internal/src/browser/instrument.ts b/packages/tracing-internal/src/browser/instrument.ts index c78f50a257e4..d40147a99734 100644 --- a/packages/tracing-internal/src/browser/instrument.ts +++ b/packages/tracing-internal/src/browser/instrument.ts @@ -208,12 +208,15 @@ function triggerHandlers(type: InstrumentHandlerType, data: unknown): void { } function instrumentCls(): StopListening { - return onCLS(metric => { - triggerHandlers('cls', { - metric, - }); - _previousCls = metric; - }); + return onCLS( + metric => { + triggerHandlers('cls', { + metric, + }); + _previousCls = metric; + }, + { reportAllChanges: true }, + ); } function instrumentFid(): void { diff --git a/packages/tracing-internal/src/browser/web-vitals/getCLS.ts b/packages/tracing-internal/src/browser/web-vitals/getCLS.ts index fdd1e867adfa..f48c217a37e5 100644 --- a/packages/tracing-internal/src/browser/web-vitals/getCLS.ts +++ b/packages/tracing-internal/src/browser/web-vitals/getCLS.ts @@ -41,7 +41,10 @@ import type { CLSMetric, ReportCallback, StopListening } from './types'; * hidden. As a result, the `callback` function might be called multiple times * during the same page load._ */ -export const onCLS = (onReport: ReportCallback): StopListening | undefined => { +export const onCLS = ( + onReport: ReportCallback, + options: { reportAllChanges?: boolean } = {}, +): StopListening | undefined => { const metric = initMetric('CLS', 0); let report: ReturnType; @@ -87,7 +90,7 @@ export const onCLS = (onReport: ReportCallback): StopListening | undefined => { const po = observe('layout-shift', handleEntries); if (po) { - report = bindReporter(onReport, metric); + report = bindReporter(onReport, metric, options.reportAllChanges); const stopListening = (): void => { handleEntries(po.takeRecords() as CLSMetric['entries']);