mirror of https://github.com/lukechilds/node.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
39 lines
1.3 KiB
39 lines
1.3 KiB
'use strict';
|
|
|
|
const common = require('../common');
|
|
const assert = require('assert');
|
|
|
|
// Make sure we test 0ms timers, since they would had always wanted to run on
|
|
// the current tick, and greater than 0ms timers, for scenarios where the
|
|
// outer timer takes longer to complete than the delay of the nested timer.
|
|
// Since the process of recreating this is identical regardless of the timer
|
|
// delay, these scenarios are in one test.
|
|
const scenarios = [0, 100];
|
|
|
|
scenarios.forEach(function(delay) {
|
|
let nestedCalled = false;
|
|
|
|
setTimeout(function A() {
|
|
// Create the nested timer with the same delay as the outer timer so that it
|
|
// gets added to the current list of timers being processed by
|
|
// listOnTimeout.
|
|
setTimeout(function B() {
|
|
nestedCalled = true;
|
|
}, delay);
|
|
|
|
// Busy loop for the same timeout used for the nested timer to ensure that
|
|
// we are in fact expiring the nested timer.
|
|
common.busyLoop(delay);
|
|
|
|
// The purpose of running this assert in nextTick is to make sure it runs
|
|
// after A but before the next iteration of the libuv event loop.
|
|
process.nextTick(function() {
|
|
assert.ok(!nestedCalled);
|
|
});
|
|
|
|
// Ensure that the nested callback is indeed called prior to process exit.
|
|
process.on('exit', function onExit() {
|
|
assert.ok(nestedCalled);
|
|
});
|
|
}, delay);
|
|
});
|
|
|