From 2963ef90b5f13d9ef1cf2e374ede11fb0582a35f Mon Sep 17 00:00:00 2001 From: Welcius Date: Mon, 3 Jan 2022 17:45:40 +0100 Subject: [PATCH] fix(errors): Set stack trace, if available Signed-off-by: Welcius --- lib/error.ts | 12 +++++++++--- test/error.test.ts | 10 ++++++++++ 2 files changed, 19 insertions(+), 3 deletions(-) diff --git a/lib/error.ts b/lib/error.ts index e5b6beab..3951830e 100644 --- a/lib/error.ts +++ b/lib/error.ts @@ -2,19 +2,25 @@ import APIErrorOptions from './interfaces/APIErrorOptions'; export default class APIError extends Error { status: number | string; - stack: string; details: string; constructor({ status, statusText, message, - body = {} + body = {}, }: APIErrorOptions) { const { message: bodyMessage, error } = body; super(); - this.stack = ''; + // Maintains proper stack trace for where our error was thrown (only available on V8) + if (Error.captureStackTrace) { + Error.captureStackTrace(this, APIError); + } else { + this.stack = ''; + } + + this.name = 'APIError'; this.status = status; this.message = message || error || statusText; this.details = bodyMessage; diff --git a/test/error.test.ts b/test/error.test.ts index b9aadb2a..7c5a9ed9 100644 --- a/test/error.test.ts +++ b/test/error.test.ts @@ -29,4 +29,14 @@ describe('APIError', function () { error.message.should.eql('oops. something went wrong'); }); + + it('is an api error', function () { + error = new APIError({ + body: { + error: 'oops. something went wrong' + } + } as APIErrorOptions); + + error.name.should.eql('APIError'); + }); });