From 9b2711679880aaf6dfa75c7d24ed886e0bf1f764 Mon Sep 17 00:00:00 2001 From: Amjad Masad Date: Wed, 9 Sep 2015 16:30:22 -0700 Subject: [PATCH] Client should throw when server unexpectedly closes the connection Reviewed By: @natthu Differential Revision: D2425357 --- packager/react-packager/src/Server/index.js | 18 +++++++++------- .../src/SocketInterface/SocketClient.js | 21 ++++++++++++++----- .../src/SocketInterface/SocketServer.js | 7 ++++++- 3 files changed, 32 insertions(+), 14 deletions(-) diff --git a/packager/react-packager/src/Server/index.js b/packager/react-packager/src/Server/index.js index 2b33f20b3..f8113dbbf 100644 --- a/packager/react-packager/src/Server/index.js +++ b/packager/react-packager/src/Server/index.js @@ -157,14 +157,16 @@ class Server { } buildBundle(options) { - const opts = bundleOpts(options); - return this._bundler.bundle( - opts.entryFile, - opts.runModule, - opts.sourceMapUrl, - opts.dev, - opts.platform - ); + return Promise.resolve().then(() => { + const opts = bundleOpts(options); + return this._bundler.bundle( + opts.entryFile, + opts.runModule, + opts.sourceMapUrl, + opts.dev, + opts.platform + ); + }); } buildBundleFromUrl(reqUrl) { diff --git a/packager/react-packager/src/SocketInterface/SocketClient.js b/packager/react-packager/src/SocketInterface/SocketClient.js index 32e3b25d7..837e7a2c2 100644 --- a/packager/react-packager/src/SocketInterface/SocketClient.js +++ b/packager/react-packager/src/SocketInterface/SocketClient.js @@ -33,10 +33,7 @@ class SocketClient { this._sock.on('error', (e) => { e.message = `Error connecting to server on ${sockPath} ` + `with error: ${e.message}`; - - if (fs.existsSync(LOG_PATH)) { - e.message += '\nServer logs:\n' + fs.readFileSync(LOG_PATH, 'utf8'); - } + e.message += getServerLogs(); reject(e); }); @@ -45,8 +42,13 @@ class SocketClient { this._resolvers = Object.create(null); const bunser = new bser.BunserBuf(); this._sock.on('data', (buf) => bunser.append(buf)); - bunser.on('value', (message) => this._handleMessage(message)); + + this._sock.on('close', () => { + if (!this._closing) { + throw new Error('Server closed unexpectedly' + getServerLogs()); + } + }); } onReady() { @@ -105,6 +107,7 @@ class SocketClient { close() { debug('closing connection'); + this._closing = true; this._sock.end(); } } @@ -115,3 +118,11 @@ function uid(len) { len = len || 7; return Math.random().toString(35).substr(2, len); } + +function getServerLogs() { + if (fs.existsSync(LOG_PATH)) { + return '\nServer logs:\n' + fs.readFileSync(LOG_PATH, 'utf8'); + } + + return ''; +} diff --git a/packager/react-packager/src/SocketInterface/SocketServer.js b/packager/react-packager/src/SocketInterface/SocketServer.js index 5778eba02..19b4b29cf 100644 --- a/packager/react-packager/src/SocketInterface/SocketServer.js +++ b/packager/react-packager/src/SocketInterface/SocketServer.js @@ -59,7 +59,12 @@ class SocketServer { const bunser = new bser.BunserBuf(); sock.on('data', (buf) => bunser.append(buf)); bunser.on('value', (m) => this._handleMessage(sock, m)); - bunser.on('error', (e) => console.error(e)); + bunser.on('error', (e) => { + e.message = 'Unhandled error from the bser buffer. ' + + 'Either error on encoding or message handling: \n' + + e.message; + throw e; + }); } _handleMessage(sock, m) {