node/test/simple/test-next-tick-ordering.js

33 lines
606 B
JavaScript

common = require("../common");
assert = common.assert
var sys = require('sys'), i;
var N = 30;
var done = [];
function get_printer(timeout) {
return function () {
console.log("Running from setTimeout " + timeout);
done.push(timeout);
};
}
process.nextTick(function () {
console.log("Running from nextTick");
done.push('nextTick');
})
for (i = 0; i < N; i += 1) {
setTimeout(get_printer(i), i);
}
console.log("Running from main.");
process.addListener('exit', function () {
assert.equal('nextTick', done[0]);
for (i = 0; i < N; i += 1) {
assert.equal(i, done[i+1]);
}
});