Skip to content

Commit

Permalink
test: enhance test-timers
Browse files Browse the repository at this point in the history
In test-timers, confirm that all input values that should be coerced to
1 ms are not being coerced to a significantly larger value.

This eliminates the need for the separate test-regress-GH-897.

PR-URL: #10960
Reviewed-By: James M Snell <[email protected]>
Reviewed-By: Luigi Pinca <[email protected]>
  • Loading branch information
Trott authored and jasnell committed Mar 8, 2017
1 parent cfbbf64 commit f866bac
Showing 1 changed file with 16 additions and 8 deletions.
24 changes: 16 additions & 8 deletions test/parallel/test-timers.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
'use strict';
require('../common');
var assert = require('assert');
const common = require('../common');
const assert = require('assert');

var inputs = [
undefined,
Expand All @@ -18,13 +18,14 @@ var inputs = [
-10,
-1,
-0.5,
-0.1,
-0.0,
0,
0.0,
0.1,
0.5,
1,
1.0,
10,
2147483648, // browser behaviour: timeouts > 2^31-1 run on next tick
12345678901234 // ditto
];
Expand All @@ -43,10 +44,17 @@ inputs.forEach(function(value, index) {
}, value);
});

process.on('exit', function() {
// assert that all timers have run
// All values in inputs array coerce to 1 ms. Therefore, they should all run
// before a timer set here for 2 ms.

setTimeout(common.mustCall(function() {
// assert that all other timers have run
inputs.forEach(function(value, index) {
assert.equal(true, timeouts[index]);
assert.equal(true, intervals[index]);
assert(timeouts[index]);
assert(intervals[index]);
});
});
}), 2);

// Test 10 ms timeout separately.
setTimeout(common.mustCall(function() {}), 10);
setInterval(common.mustCall(function() { clearInterval(this); }), 10);

0 comments on commit f866bac

Please sign in to comment.