-
-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Description
OS:
- Windows
- MacOS
- Linux
Platform:
- iOS
- Android
SDK:
-
@sentry/react-native(>= 1.0.0) -
react-native-sentry(<= 0.43.2)
SDK version: 5.15.2
react-native version: 0.72.9
react version: 18.2.0
Are you using Expo?
- Yes
- No
Are you using sentry.io or on-premise?
- sentry.io (SaaS)
- on-premise
If you are using sentry.io, please post a link to your issue so we can take a look:
Issue where the error is classified as unhandled
https://mixcloud.sentry.io/discover/ios:45b823357fd441a6bb2ccc68581d293e
Issue (in older release) where the same error is classified as handled
https://mixcloud.sentry.io/discover/ios:18fd9d35a97c4f49a920b4d1ca465d25
Configuration:
Sentry.init({
dsn: env.SENTRY,
ignoreErrors: IGNORE_ERRORS,
environment: IS_DEVELOPMENT_BUILD ? 'development' : 'production',
debug: IS_DEVELOPMENT_BUILD,
release: sentryRelease,
dist: getBuildNumber()
});
I have the following issue:
Some Javascript errors that are being thrown explicitly by our Application code are being reported as Unhandled i.e. handled: false in Sentry - yet the code that throws the error is surrounded by an ErrorBoundary and does not result in a hard crash when the error occurs. The fallback component we provide to the error boundary is triggered.
Potentially relevant is the fact that in older releases of our App where we were using react-native 0.66.5, react 17.0.2 and sentry/react-native version 4.15.0 the very same errors were thrown from the same code are reported as handled: true by Sentry.
Steps to reproduce:
- Trigger code that throws an error but is contained within an
ErrorBoundary, such as :
ExampleComponent
...
if (!cloudcast) {
throw new Error(`No cloudcast found for id ${cloudcastId}`);
}
...
Surrounding ErrorBoundary
<ErrorBoundary
fallback={fallback}
onBack={onBack}
onRetry={onRetry}
>
<OfflineBoundary fallback={fallback}>
<React.Suspense fallback={fallback}>
<ExampleComponent>
</React.Suspense>
</OfflineBoundary>
</ErrorBoundary>
Actual result:
- The fallback component renders but the error is reported to Sentry and classified as unhandled
Expected result:
- The fallback component renders and the error is reported to Sentry and classified as handled, since it has been caught by an
ErrorBoundary
Is the fact that in the Sentry issue UX (and the JSON for error) the metadata.type is React ErrorBoundary Error in the newer release where the error is classified as unhandled, and Error in the older release where the error is correctly classified as handled? As mentioned the relevant application code has not changed - but the underlying RN dependencies have.
Here is a screenshot showing the same error across the two different releases, the left-hand side is our newer release using RN0.72.9 where the error is classified as unhandled. The right-hand side is the older release where the error is classified as handled.
Can anyone think of any reason why the same error scenarios are now being classified as Unhandled by Sentry?
Metadata
Metadata
Assignees
Labels
Projects
Status
Status
