From 0df5aa44c933e417f5d933b4e9442cd285221360 Mon Sep 17 00:00:00 2001 From: Daniel Rozenberg Date: Mon, 29 Apr 2024 09:53:43 -0400 Subject: [PATCH] =?UTF-8?q?=F0=9F=8F=97=20Simplify=20error=20reporting=20t?= =?UTF-8?q?hresholds=20(#39975)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Replace magic numbers with consts * Fix incorrect comparison for non-AMP JS threshold * Reduce reporting threshold --- src/error-reporting.js | 33 ++++++++++++++++++++----------- test/unit/test-error-reporting.js | 6 +++--- 2 files changed, 25 insertions(+), 14 deletions(-) diff --git a/src/error-reporting.js b/src/error-reporting.js index 499268e8fc07..268c29dbe4e4 100644 --- a/src/error-reporting.js +++ b/src/error-reporting.js @@ -44,20 +44,35 @@ const ABORTED = 'AbortError'; * them, but we'd still like to report the rough number. * @const {number} */ -const NON_ACTIONABLE_ERROR_THROTTLE_THRESHOLD = 0.001; +const NON_ACTIONABLE_ERROR_THROTTLE_THRESHOLD = 0.0001; /** * The threshold for errors throttled because nothing can be done about * them, but we'd still like to report the rough number. * @const {number} */ -const USER_ERROR_THROTTLE_THRESHOLD = 0.1; +const USER_ERROR_THROTTLE_THRESHOLD = 0.01; /** - * Chance to post to the new error reporting endpoint. + * The threshold for reporting errors to the beta error reporting endpoint + * instead of the production endpoint. * @const {number} */ -const BETA_ERROR_REPORT_URL_FREQ = 0.1; +const REPORT_ERROR_TO_BETA_ENDPOINT_THRESHOLD = 0.1; + +/** + * The threshold for errors on pages with non-AMP JS. These errors can almost + * never be acted upon, but spikes such as due to buggy browser extensions may + * be helpful to notify authors. + * @const {number} + */ +const NON_AMP_JS_ERROR_THRESHOLD = 0.01; + +/** + * Throttles reports for the Stable version. + * @const {number} + */ +const THROTTLE_STABLE_THRESHOLD = 0.9; /** * Collects error messages, so they can be included in subsequent reports. @@ -319,10 +334,7 @@ function onError(message, filename, line, col, error) { } catch (ignore) { // Ignore errors during error report generation. } - if (hasNonAmpJs && Math.random() > 0.01) { - // Only report 1% of errors on pages with non-AMP JS. - // These errors can almost never be acted upon, but spikes such as - // due to buggy browser extensions may be helpful to notify authors. + if (hasNonAmpJs && Math.random() < NON_AMP_JS_ERROR_THRESHOLD) { return; } const data = getErrorReportData( @@ -357,7 +369,7 @@ function onError(message, filename, line, col, error) { * @return {string} error reporting endpoint URL. */ function chooseReportingUrl_() { - return Math.random() < BETA_ERROR_REPORT_URL_FREQ + return Math.random() < REPORT_ERROR_TO_BETA_ENDPOINT_THRESHOLD ? urls.betaErrorReporting : urls.errorReporting; } @@ -373,8 +385,7 @@ export function reportErrorToServerOrViewer(win, data) { // to the viewer is exactly the same as the data passed to the server // below. - // Throttle reports from Stable by 90%. - if (data['pt'] && Math.random() < 0.9) { + if (data['pt'] && Math.random() < THROTTLE_STABLE_THRESHOLD) { return Promise.resolve(); } diff --git a/test/unit/test-error-reporting.js b/test/unit/test-error-reporting.js index 7b9e95800995..edfdde9f0e89 100644 --- a/test/unit/test-error-reporting.js +++ b/test/unit/test-error-reporting.js @@ -533,7 +533,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should report throttled load errors at threshold', () => { - nextRandomNumber = 1e-3; + nextRandomNumber = 1e-4; const e = new Error('Failed to load:'); const data = getErrorReportData( undefined, @@ -560,7 +560,7 @@ describes.sandboxed('getErrorReportData', {}, (env) => { }); it('should report throttled Script errors at threshold', () => { - nextRandomNumber = 1e-3; + nextRandomNumber = 1e-4; 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-3 - 1e-4; + nextRandomNumber = 1e-4 - 1e-5; const e = new Error('Failed to load:'); const data = getErrorReportData( undefined,