2010-07-16 02:47:25 +08:00
|
|
|
common = require("../common");
|
|
|
|
assert = common.assert
|
2010-04-14 06:39:15 +08:00
|
|
|
var sys = require('sys'), i;
|
|
|
|
|
|
|
|
var N = 30;
|
|
|
|
var done = [];
|
|
|
|
|
|
|
|
function get_printer(timeout) {
|
|
|
|
return function () {
|
2010-06-24 08:40:51 +08:00
|
|
|
console.log("Running from setTimeout " + timeout);
|
2010-04-14 06:39:15 +08:00
|
|
|
done.push(timeout);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
process.nextTick(function () {
|
2010-06-24 08:40:51 +08:00
|
|
|
console.log("Running from nextTick");
|
2010-04-14 06:39:15 +08:00
|
|
|
done.push('nextTick');
|
|
|
|
})
|
|
|
|
|
|
|
|
for (i = 0; i < N; i += 1) {
|
|
|
|
setTimeout(get_printer(i), i);
|
|
|
|
}
|
|
|
|
|
2010-06-24 08:40:51 +08:00
|
|
|
console.log("Running from main.");
|
2010-04-14 06:39:15 +08:00
|
|
|
|
|
|
|
|
|
|
|
process.addListener('exit', function () {
|
|
|
|
assert.equal('nextTick', done[0]);
|
|
|
|
for (i = 0; i < N; i += 1) {
|
|
|
|
assert.equal(i, done[i+1]);
|
|
|
|
}
|
|
|
|
});
|