Browse Source

Capture the unhandled exceptions of the process

master
Gaëtan Renaudeau 7 years ago
parent
commit
c993f97c5d
  1. 8
      src/internals/index.js
  2. 8
      src/main/bridge.js

8
src/internals/index.js

@ -11,6 +11,14 @@ require('../env')
process.title = 'Internal' process.title = 'Internal'
process.on('uncaughtException', err => {
process.send({
type: 'uncaughtException',
error: serializeError(err),
})
process.exit(1)
})
const defers = {} const defers = {}
let sentryEnabled = process.env.INITIAL_SENTRY_ENABLED || false let sentryEnabled = process.env.INITIAL_SENTRY_ENABLED || false

8
src/main/bridge.js

@ -7,8 +7,9 @@ import { ipcMain, app } from 'electron'
import { ipcMainListenReceiveCommands } from 'helpers/ipc' import { ipcMainListenReceiveCommands } from 'helpers/ipc'
import path from 'path' import path from 'path'
import logger from 'logger' import logger from 'logger'
import sentry from 'sentry/node' import sentry, { captureException } from 'sentry/node'
import user from 'helpers/user' import user from 'helpers/user'
import { deserializeError } from 'helpers/errors'
import setupAutoUpdater, { quitAndInstall } from './autoUpdate' import setupAutoUpdater, { quitAndInstall } from './autoUpdate'
import { setInternalProcessPID } from './terminator' import { setInternalProcessPID } from './terminator'
@ -100,6 +101,11 @@ ipcMainListenReceiveCommands({
function handleGlobalInternalMessage(payload) { function handleGlobalInternalMessage(payload) {
switch (payload.type) { switch (payload.type) {
case 'uncaughtException': {
const err = deserializeError(payload.error)
captureException(err)
break
}
case 'setLibcoreBusy': case 'setLibcoreBusy':
case 'setDeviceBusy': case 'setDeviceBusy':
case 'executeHttpQueryOnRenderer': { case 'executeHttpQueryOnRenderer': {

Loading…
Cancel
Save