-
-
Notifications
You must be signed in to change notification settings - Fork 125
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat: error boundary in layout to handle application errors / crashes #1108
base: master
Are you sure you want to change the base?
feat: error boundary in layout to handle application errors / crashes #1108
Conversation
…i-react into ErrorBoundary-in-layout
Quality Gate passedIssues Measures |
In Firefox:In Chrome:The Error Boundary is detecting the error being generated by the browser on too much recursion and rendering the Error component. Used this asyncapi document for testing asyncapi: 3.0.0
info:
title: Account Service
version: 1.0.0
description: This service is in charge of processing user signups
channels:
userSignedup:
address: user/signedup
messages:
UserSignedUp:
$ref: '#/components/messages/UserSignedUp'
x-recursion: #RECURSION here
$ref: '#'
operations:
sendUserSignedup:
action: send
channel:
$ref: '#/channels/userSignedup'
messages:
- $ref: '#/channels/userSignedup/messages/UserSignedUp'
x-recursion: #RECURSION here
$ref: '#'
components:
messages:
UserSignedUp:
x-recursion: #RECURSION here
$ref: '#'
payload:
type: object
properties:
x-recursion: #RECURSION here
$ref: '#'
displayName:
type: string
description: Name of the user
email:
type: string |
@reachaadrika could you please review this pull request too when you get a chance? 😄 Thanks in advance! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
awesome improvement, but i noticed when i fix the recursive properties in the schema, the error still persists in the UI until i either refresh or re-paste a valid schema 🤔
{configShow.sidebar && <Sidebar />} | ||
<div className="panel--center relative py-8 flex-1"> | ||
<div className="relative z-10"> | ||
{configShow.errors && error && <Error error={error} />} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is this line still relevant? i mean since you've imported the error boundary in the layout container and it already includes the error component.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes it is important.
This line handles the errors in our document when parsing it. The errors are in turn diagnostics with severity 0. Introduced in this PR: https://github.com/asyncapi/asyncapi-react/pull/1082/files
The error boundary, on the other hand, is used to catch unexpected application errors, such as a recursion error, and is a separate concern.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This line handles the errors in our document when parsing it. The errors are in turn diagnostics with severity 0.
Aren't we already handling these errors here
concatenatedConfig.show?.errors && ( |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The error boundary, on the other hand, is used to catch unexpected application errors, such as a recursion error, and is a separate concern.
I agree with you 👍🏾
my question now is if {configShow.errors && error && <Error error={error} />}
is relevant if we are already handling it in the standalone code, don't you think?
Description
As proposed and discussed here #1101 (comment).
Changes proposed in this pull request:
Added an error boundary in layout to handle errors generated by infinite recursion and such so that the application doesnt crash into an irrecoverable state.
Reused the already existing Error component to render error,
Related issue(s)
#1100