[Glitch] Add source-mapped stacktrace to error message in web UI
Port 729fe5bfd6 to glitch-soc
			
			
This commit is contained in:
		
							parent
							
								
									2f977ac8f3
								
							
						
					
					
						commit
						b4be41e4c4
					
				
					 1 changed files with 20 additions and 2 deletions
				
			
		|  | @ -2,6 +2,7 @@ import React from 'react'; | ||||||
| import PropTypes from 'prop-types'; | import PropTypes from 'prop-types'; | ||||||
| import { FormattedMessage } from 'react-intl'; | import { FormattedMessage } from 'react-intl'; | ||||||
| import { preferencesLink } from 'flavours/glitch/util/backend_links'; | import { preferencesLink } from 'flavours/glitch/util/backend_links'; | ||||||
|  | import StackTrace from 'stacktrace-js'; | ||||||
| 
 | 
 | ||||||
| export default class ErrorBoundary extends React.PureComponent { | export default class ErrorBoundary extends React.PureComponent { | ||||||
| 
 | 
 | ||||||
|  | @ -11,15 +12,29 @@ export default class ErrorBoundary extends React.PureComponent { | ||||||
| 
 | 
 | ||||||
|   state = { |   state = { | ||||||
|     hasError: false, |     hasError: false, | ||||||
|  |     errorMessage: undefined, | ||||||
|     stackTrace: undefined, |     stackTrace: undefined, | ||||||
|  |     mappedStackTrace: undefined, | ||||||
|     componentStack: undefined, |     componentStack: undefined, | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   componentDidCatch(error, info) { |   componentDidCatch(error, info) { | ||||||
|     this.setState({ |     this.setState({ | ||||||
|       hasError: true, |       hasError: true, | ||||||
|  |       errorMessage: error.toString(), | ||||||
|       stackTrace: error.stack, |       stackTrace: error.stack, | ||||||
|       componentStack: info && info.componentStack, |       componentStack: info && info.componentStack, | ||||||
|  |       mappedStackTrace: undefined, | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     StackTrace.fromError(error).then((stackframes) => { | ||||||
|  |       this.setState({ | ||||||
|  |         mappedStackTrace: stackframes.map((sf) => sf.toString()).join('\n'), | ||||||
|  |       }); | ||||||
|  |     }).catch(() => { | ||||||
|  |       this.setState({ | ||||||
|  |         mappedStackTrace: undefined, | ||||||
|  |       }); | ||||||
|     }); |     }); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|  | @ -29,13 +44,16 @@ export default class ErrorBoundary extends React.PureComponent { | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   render() { |   render() { | ||||||
|     const { hasError, stackTrace, componentStack } = this.state; |     const { hasError, errorMessage, stackTrace, mappedStackTrace, componentStack } = this.state; | ||||||
| 
 | 
 | ||||||
|     if (!hasError) return this.props.children; |     if (!hasError) return this.props.children; | ||||||
| 
 | 
 | ||||||
|     let debugInfo = ''; |     let debugInfo = ''; | ||||||
|     if (stackTrace) { |     if (stackTrace) { | ||||||
|       debugInfo += 'Stack trace\n-----------\n\n```\n' + stackTrace.toString() + '\n```'; |       debugInfo += 'Stack trace\n-----------\n\n```\n' + errorMessage + '\n' + stackTrace.toString() + '\n```'; | ||||||
|  |     } | ||||||
|  |     if (mappedStackTrace) { | ||||||
|  |       debugInfo += 'Mapped stack trace\n-----------\n\n```\n' + errorMessage + '\n' + mappedStackTrace.toString() + '\n```'; | ||||||
|     } |     } | ||||||
|     if (componentStack) { |     if (componentStack) { | ||||||
|       if (debugInfo) { |       if (debugInfo) { | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue