mirror of
https://github.com/nodejs/node.git
synced 2024-11-25 08:19:38 +01:00
3b1b4de903
Timeout#unref() call returns undefined, not this. The test already worked before, because the interval was still unref'd, and the test also succeeds without clearing the interval. PR-URL: https://github.com/joyent/node/pull/9171 Reviewed-by: Colin Ihrig <cjihrig@gmail.com> Reviewed-by: Timothy J Fontaine <tjfontaine@gmail.com> Conflicts: test/simple/test-timers-unref.js
50 lines
1.3 KiB
JavaScript
50 lines
1.3 KiB
JavaScript
var common = require('../common');
|
|
var assert = require('assert');
|
|
|
|
var interval_fired = false,
|
|
timeout_fired = false,
|
|
unref_interval = false,
|
|
unref_timer = false,
|
|
interval, check_unref, checks = 0;
|
|
|
|
var LONG_TIME = 10 * 1000;
|
|
var SHORT_TIME = 100;
|
|
|
|
setInterval(function() {
|
|
interval_fired = true;
|
|
}, LONG_TIME).unref();
|
|
|
|
setTimeout(function() {
|
|
timeout_fired = true;
|
|
}, LONG_TIME).unref();
|
|
|
|
interval = setInterval(function() {
|
|
unref_interval = true;
|
|
clearInterval(interval);
|
|
}, SHORT_TIME);
|
|
interval.unref();
|
|
|
|
setTimeout(function() {
|
|
unref_timer = true;
|
|
}, SHORT_TIME).unref();
|
|
|
|
check_unref = setInterval(function() {
|
|
if (checks > 5 || (unref_interval && unref_timer))
|
|
clearInterval(check_unref);
|
|
checks += 1;
|
|
}, 100);
|
|
|
|
// Should not assert on args.Holder()->InternalFieldCount() > 0. See #4261.
|
|
(function() {
|
|
var t = setInterval(function() {}, 1);
|
|
process.nextTick(t.unref.bind({}));
|
|
process.nextTick(t.unref.bind(t));
|
|
})();
|
|
|
|
process.on('exit', function() {
|
|
assert.strictEqual(interval_fired, false, 'Interval should not fire');
|
|
assert.strictEqual(timeout_fired, false, 'Timeout should not fire');
|
|
assert.strictEqual(unref_timer, true, 'An unrefd timeout should still fire');
|
|
assert.strictEqual(unref_interval, true, 'An unrefd interval should still fire');
|
|
});
|