2015-05-19 13:00:06 +02:00
|
|
|
'use strict';
|
2016-12-29 17:55:51 +01:00
|
|
|
require('../common');
|
|
|
|
|
2014-08-26 20:45:12 +02:00
|
|
|
/*
|
|
|
|
* This test makes sure that non-integer timer delays do not make the process
|
|
|
|
* hang. See https://github.com/joyent/node/issues/8065 and
|
|
|
|
* https://github.com/joyent/node/issues/8068 which have been fixed by
|
|
|
|
* https://github.com/joyent/node/pull/8073.
|
|
|
|
*
|
|
|
|
* If the process hangs, this test will make the tests suite timeout,
|
|
|
|
* otherwise it will exit very quickly (after 50 timers with a short delay
|
|
|
|
* fire).
|
|
|
|
*
|
|
|
|
* We have to set at least several timers with a non-integer delay to
|
|
|
|
* reproduce the issue. Sometimes, a timer with a non-integer delay will
|
|
|
|
* expire correctly. 50 timers has always been more than enough to reproduce
|
|
|
|
* it 100%.
|
|
|
|
*/
|
|
|
|
|
2016-12-29 17:55:51 +01:00
|
|
|
const TIMEOUT_DELAY = 1.1;
|
|
|
|
const NB_TIMEOUTS_FIRED = 50;
|
2014-08-26 20:45:12 +02:00
|
|
|
|
2016-12-29 17:55:51 +01:00
|
|
|
let nbTimeoutFired = 0;
|
|
|
|
const interval = setInterval(function() {
|
2014-08-26 20:45:12 +02:00
|
|
|
++nbTimeoutFired;
|
|
|
|
if (nbTimeoutFired === NB_TIMEOUTS_FIRED) {
|
|
|
|
clearInterval(interval);
|
|
|
|
process.exit(0);
|
|
|
|
}
|
|
|
|
}, TIMEOUT_DELAY);
|