long stack traces for node.js
long stack traces for node.js over async/io boundaries
npm install superstack
superstack in your project. Ideally one of the first requires (see how it works for why)
var superstack = require'superstack';
Your stack traces will now extend beyond async call boundaries.
By default, the stacktrace appears as one long stacktrace. If you want to see the superstack framing boundaries set this value to a string and it will appear in the callstack.
Set this to a positive number to limit the number of frames superstack will capture. This is how many nested async calls back to report. A values of
-1 means unlimited. Default is
Function used by superstack to format the stacktrace string. See the implementation for default. The default conforms to the v8 stacktrace strings.
Superstack works by intercepting certain node.js EventEmitter, process, and Timer APIs. By intercepting the api call and injecting a wrapper callback, any error can be captured and additional frame information added via Error.prepareStackTrace
The following calls are intercepted.
If you find an instance of async usage that is not properly captured, please open an issue and provide a testcase to reproduce.