nodeunit icon indicating copy to clipboard operation
nodeunit copied to clipboard

fatal errors in test callbacks are not displayed (with fix)

Open andrasq opened this issue 10 years ago • 5 comments

Fatal errors in callbacks defined in the test functions are not displayed, only the "test.done() not called" diagnostic is shown. It's useful to have the error and line number too. (If not in a callback, the error is reported as expected.)

To reproduce the issue, create a file t.js:

module.exports = {
    test: function(t) {
        var x;
        setTimeout(function() {
            x.a = 1;
        }, 1);
    }
}

Current nodeunit outputs:

% nodeunit t.js

t.js

FAILURES: Undone tests (or their setups/teardowns): 
- test

To fix this, make sure all tests call test.done()

with the propsed fix it outputs:

% nodeunit t.js

t.js
Uncaught exception:
TypeError: Cannot set property 'a' of undefined
    at null._onTimeout (/home/andras/node/t.js:5:21)
    at Timer.listOnTimeout [as ontimeout] (timers.js:110:15)

FAILURES: Undone tests (or their setups/teardowns): 
- test

To fix this, make sure all tests call test.done()

The proposed fix:

diff --git a/lib/track.js b/lib/track.js
index 5af98ad..f699fce 100644
--- a/lib/track.js
+++ b/lib/track.js
@@ -27,6 +27,11 @@ exports.createTracker = function (on_exit) {
         }
     };

+    // AR: display errors in callbacks defined within the tests
+    process.on('uncaughtException', function(e) {
+        console.log("Uncaught exception:\n" + e.stack);
+    });
+
     process.on('exit', function() {
         on_exit = on_exit || exports.default_on_exit;
         on_exit(tracker);

andrasq avatar Sep 27 '14 19:09 andrasq

I want this too, but see issue #177 :-(

rpaterson avatar Sep 29 '14 17:09 rpaterson

With my PR #281 the output of your test t.js above is:

rpaterson@baloo2:nodeunit (domains)$ dist/nodeunit/bin/nodeunit t.js 

t.js
✖ test

TypeError: Cannot set property 'a' of undefined
  at [object Object]._onTimeout (/home/rpaterson/Programming/signpost/nodeunit/t.js:5:17)
  at Timer.listOnTimeout [as ontimeout] (timers.js:112:15)



FAILURES: 1/1 assertions failed (9ms)

rpaterson avatar Sep 29 '14 21:09 rpaterson

@rpaterson, your output is cleaner, works for me! If not yours, my "fix" is passive and doesn't change the active code.

andrasq avatar Sep 29 '14 22:09 andrasq

:+1:

eladb avatar Feb 24 '15 20:02 eladb

Huge +1 here. Can we get this PR in? https://github.com/caolan/nodeunit/pull/281

nategood avatar Apr 13 '15 17:04 nategood