add robustness when we run the electron process and move the exit

controller inside the main js file
pull/1/head
Chocobozzz 2015-11-02 22:19:39 +01:00
parent 3a443402a6
commit 0ae2e7f73c
4 changed files with 33 additions and 9 deletions

View File

@ -150,6 +150,18 @@
if (err) throw err
// Create/activate the webtorrent module
webtorrent.create(function () {
function cleanForExit () {
utils.cleanForExit(webtorrent.app)
}
function exitGracefullyOnSignal () {
process.exit()
}
process.on('exit', cleanForExit)
process.on('SIGINT', exitGracefullyOnSignal)
process.on('SIGTERM', exitGracefullyOnSignal)
// ----------- Make the server listening -----------
server.listen(port, function () {
videos.seedAll(function () {

View File

@ -186,5 +186,10 @@
return dec
}
utils.cleanForExit = function (webtorrent_process) {
logger.info('Gracefully exiting')
process.kill(-webtorrent_process.pid)
}
module.exports = utils
})()

View File

@ -43,11 +43,23 @@
ipc.serve(function () {
if (!webtorrentnode.silent) logger.info('IPC server ready.')
// Run a timeout of 30s after which we exit the process
var timeout_webtorrent_process = setTimeout(function () {
logger.error('Timeout : cannot run the webtorrent process. Please ensure you have electron-prebuilt npm package installed with xvfb-run.')
process.exit()
}, 30000)
ipc.server.on(processKey + '.ready', function () {
if (!webtorrentnode.silent) logger.info('Webtorrent process ready.')
clearTimeout(timeout_webtorrent_process)
callback()
})
ipc.server.on(processKey + '.exception', function (data) {
logger.error('Received exception error from webtorrent process.', { exception: data.exception })
process.exit()
})
var webtorrent_process = spawn(__dirname + '/webtorrent.js', host, port, { detached: true })
webtorrent_process.stderr.on('data', function (data) {
// logger.debug('Webtorrent process stderr: ', data.toString())
@ -57,15 +69,6 @@
// logger.debug('Webtorrent process:', data.toString())
})
function exitChildProcess () {
if (!webtorrentnode.silent) logger.info('Gracefully exit child')
process.kill(-webtorrent_process.pid)
process.exit(0)
}
process.on('SIGINT', exitChildProcess)
process.on('SIGTERM', exitChildProcess)
webtorrentnode.app = webtorrent_process
})

View File

@ -83,5 +83,9 @@
ipc.of[nodeKey].emit(processKey + '.ready')
console.log('Ready.')
})
process.on('uncaughtException', function (e) {
ipc.of[nodeKey].emit(processKey + '.exception', { exception: e })
})
}
})()