summaryrefslogtreecommitdiff
path: root/test/simple/test-next-tick-ordering.js
blob: b6df02136a04b8935d97ce452a6dd032ebec9d4d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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]);
  }
});