axios-better-stacktrace
Axios plugin that provides better stack traces for axios errors.
Check this axios issue for more details.
Installation
NPM
npm install axios-better-stacktrace
Yarn
yarn add axios-better-stacktrace
Note
It was tested with axios 0.21.0
.
Usage
import axiosBetterStacktrace from 'axios-better-stacktrace';
axiosBetterStacktrace(axiosAgent);
axiosAgent.get('https://npmjs.com/<not-found>/').catch(enhancedError => console.error(enhancedError));
(async () => {
try {
await axiosAgent.get('https://npmjs.com/<not-found>/');
} catch (enhancedError) {
console.error(enhancedError);
}
})();
axiosAgent.interceptors.response.use(response => response, enhancedError => {
console.error(enhancedError);
return result;
});
const restoreAgent = axiosBetterStacktrace(axiosAgent);
restoreAgent && restoreAgent();
See also demo.
Options
Name | Type | Default | Description |
---|
errorMsg | String | Axios Better Stacktrace | Error message to show next to the original one in the output. |
Example
Default axios error without an axios-better-stacktrace
plugin:
Error: Request failed with status code 404
at createError (./node_modules/axios/lib/core/createError.js:16:15)
at settle (./node_modules/axios/lib/core/settle.js:17:12)
at IncomingMessage.handleStreamEnd (./node_modules/axios/lib/adapters/http.js:244:11)
at IncomingMessage.emit (node:events:388:22)
at IncomingMessage.EventEmitter.emit (node:domain:470:12)
at endReadableNT (node:internal/streams/readable:1294:12)
at processTicksAndRejections (node:internal/process/task_queues:80:21)
Enhanced axios error with an axios-better-stacktrace
plugin (run yarn demo
to see):
Error: Request failed with status code 404
at createError (./node_modules/axios/lib/core/createError.js:16:15)
at settle (./node_modules/axios/lib/core/settle.js:17:12)
at IncomingMessage.handleStreamEnd (./node_modules/axios/lib/adapters/http.js:244:11)
at IncomingMessage.emit (node:events:388:22)
at IncomingMessage.EventEmitter.emit (node:domain:470:12)
at endReadableNT (node:internal/streams/readable:1294:12)
at processTicksAndRejections (node:internal/process/task_queues:80:21)
Error: Axios Better Stacktrace
at Function.axiosBetterStacktraceMethodProxy [as get] (./src/axiosBetterStacktrace.ts:167:15)
at getNpmPage (./demo/index.ts:10:35) <---- this is what usually useful to know for further debugging and this plugin adds 🙂
at ./demo/index.ts:13:9
at step (./demo/index.ts:33:23)
at Object.next (./demo/index.ts:14:53)
at ./demo/index.ts:8:71
at new Promise (<anonymous>)
at __awaiter (./demo/index.ts:4:12)
at ./demo/index.ts:12:2
at Object.<anonymous> (./demo/index.ts:16:3)