From 03d33c4e616c6b08bed075de5ae2be5819f92501 Mon Sep 17 00:00:00 2001 From: Daniel Rozenberg Date: Mon, 20 May 2024 12:12:58 -0400 Subject: [PATCH 1/2] Fix incorrect throttle function for error reporting --- src/error-reporting.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/error-reporting.js b/src/error-reporting.js index 268c29dbe4e46..20f747708e309 100644 --- a/src/error-reporting.js +++ b/src/error-reporting.js @@ -526,7 +526,7 @@ export function getErrorReportData( ) { expected = true; - if (throttleBase > NON_ACTIONABLE_ERROR_THROTTLE_THRESHOLD) { + if (throttleBase < NON_ACTIONABLE_ERROR_THROTTLE_THRESHOLD) { return; } } @@ -534,7 +534,7 @@ export function getErrorReportData( const isUserError = isUserErrorMessage(message); // Only report a subset of user errors. - if (isUserError && throttleBase > USER_ERROR_THROTTLE_THRESHOLD) { + if (isUserError && throttleBase < USER_ERROR_THROTTLE_THRESHOLD) { return; } From d960227fd0b332457d06ce166826cb2549701a50 Mon Sep 17 00:00:00 2001 From: Daniel Rozenberg Date: Mon, 20 May 2024 12:48:07 -0400 Subject: [PATCH 2/2] Fix tests --- test/unit/test-error-reporting.js | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/test/unit/test-error-reporting.js b/test/unit/test-error-reporting.js index edfdde9f0e892..6325f4213fc4e 100644 --- a/test/unit/test-error-reporting.js +++ b/test/unit/test-error-reporting.js @@ -189,7 +189,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { beforeEach(() => { onError = window.onerror; - nextRandomNumber = 0; + nextRandomNumber = 1; env.sandbox.stub(Math, 'random').callsFake(() => nextRandomNumber); self.__AMP_MODE = undefined; }); @@ -500,7 +500,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should throttle user errors', () => { - nextRandomNumber = 0.2; + nextRandomNumber = 0.0099999; let e = ''; allowConsoleError(() => { try { @@ -520,7 +520,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should not report load errors', () => { - nextRandomNumber = 1e-3 + 1e-4; + nextRandomNumber = 0.000099999; const e = new Error('Failed to load:'); const data = getErrorReportData( undefined, @@ -533,7 +533,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should report throttled load errors at threshold', () => { - nextRandomNumber = 1e-4; + nextRandomNumber = 0.0001; const e = new Error('Failed to load:'); const data = getErrorReportData( undefined, @@ -547,7 +547,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should not report Script errors', () => { - nextRandomNumber = 1e-3 + 1e-4; + nextRandomNumber = 0.000099999; const e = new Error('Script error.'); const data = getErrorReportData( undefined, @@ -560,7 +560,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should report throttled Script errors at threshold', () => { - nextRandomNumber = 1e-4; + nextRandomNumber = 0.0001; const e = new Error('Script error.'); const data = getErrorReportData( undefined, @@ -574,7 +574,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should report throttled load errors under threshold', () => { - nextRandomNumber = 1e-4 - 1e-5; + nextRandomNumber = 0.0001; const e = new Error('Failed to load:'); const data = getErrorReportData( undefined,