Sentry: filter out useless events, tag ErrorBoundary page crashes

This commit is contained in:
Alex Gleason 2022-08-25 13:49:08 -05:00
parent 5ad4303c3e
commit f8f8b4f2b9
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
2 changed files with 28 additions and 3 deletions

View file

@ -56,7 +56,12 @@ class ErrorBoundary extends React.PureComponent<Props, State> {
textarea: HTMLTextAreaElement | null = null; textarea: HTMLTextAreaElement | null = null;
componentDidCatch(error: any, info: any): void { componentDidCatch(error: any, info: any): void {
captureException(error); captureException(error, {
tags: {
// Allow page crashes to be easily searched in Sentry.
ErrorBoundary: 'yes',
},
});
this.setState({ this.setState({
hasError: true, hasError: true,

View file

@ -1,5 +1,7 @@
import * as BuildConfig from 'soapbox/build_config'; import * as BuildConfig from 'soapbox/build_config';
import type { CaptureContext } from '@sentry/types';
export const start = (): void => { export const start = (): void => {
Promise.all([ Promise.all([
import(/* webpackChunkName: "error" */'@sentry/react'), import(/* webpackChunkName: "error" */'@sentry/react'),
@ -11,6 +13,24 @@ export const start = (): void => {
debug: false, debug: false,
integrations: [new Integrations.BrowserTracing()], integrations: [new Integrations.BrowserTracing()],
// Filter events.
// https://docs.sentry.io/platforms/javascript/configuration/filtering/
ignoreErrors: [
// Network errors.
'AxiosError',
// sw.js couldn't be downloaded.
'Failed to update a ServiceWorker for scope',
// The user decided not to share (eg `navigator.share()`).
// This exception is useful for a try/catch flow, but not for error monitoring.
'AbortError: Share canceled',
],
denyUrls: [
// Browser extensions.
/extensions\//i,
/^chrome:\/\//i,
/^moz-extension:\/\//i,
],
// We recommend adjusting this value in production, or using tracesSampler // We recommend adjusting this value in production, or using tracesSampler
// for finer control // for finer control
tracesSampleRate: 1.0, tracesSampleRate: 1.0,
@ -18,10 +38,10 @@ export const start = (): void => {
}).catch(console.error); }).catch(console.error);
}; };
export const captureException = (error: Error): void => { export const captureException = (exception: any, captureContext?: CaptureContext | undefined): void => {
import(/* webpackChunkName: "error" */'@sentry/react') import(/* webpackChunkName: "error" */'@sentry/react')
.then(Sentry => { .then(Sentry => {
Sentry.captureException(error); Sentry.captureException(exception, captureContext);
}) })
.catch(console.error); .catch(console.error);
}; };