diff --git a/src/node.js b/src/node.js index ef276ec46da..76dd8a6a224 100644 --- a/src/node.js +++ b/src/node.js @@ -892,7 +892,12 @@ Module.prototype.loadScript = function (filename, loadPromise) { + "\n}; __wrap__;"; var compiledWrapper = process.compile(wrapper, filename); - compiledWrapper.apply(self.exports, [self.exports, require, self, filename]); + try { + compiledWrapper.apply(self.exports, [self.exports, require, self, filename]); + } catch (e) { + loadPromise.emitError(e); + return; + } self.waitChildrenLoad(function () { self.loaded = true; diff --git a/test/mjsunit/fixtures/throws_error.js b/test/mjsunit/fixtures/throws_error.js new file mode 100644 index 00000000000..728ece555f5 --- /dev/null +++ b/test/mjsunit/fixtures/throws_error.js @@ -0,0 +1 @@ +throw new Error("blah"); diff --git a/test/mjsunit/test-module-loading.js b/test/mjsunit/test-module-loading.js index bba920b9bb0..c6aea253846 100644 --- a/test/mjsunit/test-module-loading.js +++ b/test/mjsunit/test-module-loading.js @@ -33,6 +33,14 @@ assert.equal("D", d3.D()); assert.equal(true, d4.D instanceof Function); assert.equal("D", d4.D()); +var errorThrown = false; +try { + require("./fixtures/throws_error"); +} catch (e) { + errorThrown = true; + assert.equal("blah", e.message); +} + process.addListener("exit", function () { assert.equal(true, a.A instanceof Function); assert.equal("A done", a.A()); @@ -49,5 +57,7 @@ process.addListener("exit", function () { assert.equal(true, d2.D instanceof Function); assert.equal("D done", d2.D()); + assert.equal(true, errorThrown); + puts("exit"); });