Sentry: filter out useless events, tag ErrorBoundary page crashes
This commit is contained in:
parent
5ad4303c3e
commit
f8f8b4f2b9
2 changed files with 28 additions and 3 deletions
|
@ -56,7 +56,12 @@ class ErrorBoundary extends React.PureComponent<Props, State> {
|
|||
textarea: HTMLTextAreaElement | null = null;
|
||||
|
||||
componentDidCatch(error: any, info: any): void {
|
||||
captureException(error);
|
||||
captureException(error, {
|
||||
tags: {
|
||||
// Allow page crashes to be easily searched in Sentry.
|
||||
ErrorBoundary: 'yes',
|
||||
},
|
||||
});
|
||||
|
||||
this.setState({
|
||||
hasError: true,
|
||||
|
|
|
@ -1,5 +1,7 @@
|
|||
import * as BuildConfig from 'soapbox/build_config';
|
||||
|
||||
import type { CaptureContext } from '@sentry/types';
|
||||
|
||||
export const start = (): void => {
|
||||
Promise.all([
|
||||
import(/* webpackChunkName: "error" */'@sentry/react'),
|
||||
|
@ -11,6 +13,24 @@ export const start = (): void => {
|
|||
debug: false,
|
||||
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
|
||||
// for finer control
|
||||
tracesSampleRate: 1.0,
|
||||
|
@ -18,10 +38,10 @@ export const start = (): void => {
|
|||
}).catch(console.error);
|
||||
};
|
||||
|
||||
export const captureException = (error: Error): void => {
|
||||
export const captureException = (exception: any, captureContext?: CaptureContext | undefined): void => {
|
||||
import(/* webpackChunkName: "error" */'@sentry/react')
|
||||
.then(Sentry => {
|
||||
Sentry.captureException(error);
|
||||
Sentry.captureException(exception, captureContext);
|
||||
})
|
||||
.catch(console.error);
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue