fix nested remoting function throwing error will crash app

Signed-off-by: Clark Wang <clark.wangs@gmail.com>
This commit is contained in:
Clark Wang 2014-12-10 12:04:56 +08:00
parent cb2f40bb86
commit b204367aa6
2 changed files with 30 additions and 2 deletions

View File

@ -674,7 +674,11 @@ Model.nestRemoting = function(relationName, options, cb) {
this[getterName](fkId, function(err, inst) {
if (err && cb) return cb(err);
if (inst instanceof relation.modelTo) {
nestedFn.apply(inst, args);
try {
nestedFn.apply(inst, args);
} catch (err) {
cb(err);
}
} else if (cb) {
cb(err, null);
}
@ -688,7 +692,11 @@ Model.nestRemoting = function(relationName, options, cb) {
this[getterName](function(err, inst) {
if (err && cb) return cb(err);
if (inst instanceof relation.modelTo) {
nestedFn.apply(inst, args);
try {
nestedFn.apply(inst, args);
} catch (err) {
cb(err);
}
} else if (cb) {
cb(err, null);
}

View File

@ -1168,6 +1168,13 @@ describe('relations - integration', function() {
Page.hasMany(Note);
Image.belongsTo(Book);
// fake a remote method that match the filter in Model.nestRemoting()
Page.prototype.__throw__errors = function () {
throw new Error('This should not crash the app');
};
Page.remoteMethod('__throw__errors', { isStatic: false, http: { path: '/throws', verb: 'get' } });
Book.nestRemoting('pages');
Image.nestRemoting('book');
@ -1305,6 +1312,19 @@ describe('relations - integration', function() {
});
});
});
it('should catch error if nested function throws', function (done) {
var test = this;
this.get('/api/books/' + test.book.id + '/pages/' + this.page.id + '/throws')
.end(function(err, res) {
expect(res.body).to.be.an('object');
expect(res.body.error).to.be.an('object');
expect(res.body.error.name).to.equal('Error');
expect(res.body.error.status).to.equal(500);
expect(res.body.error.message).to.equal('This should not crash the app');
done();
});
});
});
});