From 350830c5a54b700ffe943aefb5e556546fbf6bf5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Miroslav=20Bajto=C5=A1?= Date: Thu, 2 Apr 2015 13:49:04 +0200 Subject: [PATCH] Forward invocation error details Most notably always set `err.statusCode`. --- lib/http-invocation.js | 8 +++--- test/http-invocation.test.js | 49 ++++++++++++++++++++++++++++++++++++ 2 files changed, 54 insertions(+), 3 deletions(-) diff --git a/lib/http-invocation.js b/lib/http-invocation.js index b276653..c85d86c 100644 --- a/lib/http-invocation.js +++ b/lib/http-invocation.js @@ -264,11 +264,13 @@ HttpInvocation.prototype.transformResponse = function(res, body, callback) { if (hasError) { if (isObject && body.error) { err = new Error(body.error.message); - err.name = body.error.name; - err.stack = body.error.stack; - err.details = body.error.details; + for (var key in body.error) { + err[key] = body.error[key]; + } } else { err = new Error('Error: ' + res.statusCode); + err.statusCode = res.statusCode; + err.details = body; } return callback(err); diff --git a/test/http-invocation.test.js b/test/http-invocation.test.js index 8a52ec2..b3f55b7 100644 --- a/test/http-invocation.test.js +++ b/test/http-invocation.test.js @@ -131,6 +131,55 @@ describe('HttpInvocation', function() { this.foo = data.foo; } }); + + it('should forward all error properties', function(done) { + var method = givenSharedStaticMethod({}); + var inv = new HttpInvocation(method); + var res = { + statusCode: 555, + body: { + error: { + name: 'CustomError', + message: 'Custom error message', + statusCode: 555, + details: { + key: 'value' + }, + extra: 'extra value' + } + } + }; + + inv.transformResponse(res, res.body, function(err) { + if (!err) + return done(new Error('transformResponse should have failed.')); + + expect(err).to.have.property('name', 'CustomError'); + expect(err).to.have.property('message', 'Custom error message'); + expect(err).to.have.property('statusCode', 555); + expect(err).to.have.property('details').eql({ key: 'value' }); + expect(err).to.have.property('extra', 'extra value'); + done(); + }); + }); + + it('should forward statusCode and non-object error response', function(done) { + var method = givenSharedStaticMethod({}); + var inv = new HttpInvocation(method); + var res = { + statusCode: 555, + body: 'error body' + }; + + inv.transformResponse(res, res.body, function(err) { + if (!err) + return done(new Error('transformResponse should have failed.')); + + expect(err).to.have.property('statusCode', 555); + expect(err).to.have.property('details', 'error body'); + done(); + }); + }); }); });