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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
#!/usr/bin/env node
var assert = require('assert');
var qjob = require('../qjobs');
var maxConcurrency = 2;
var q = new qjob({maxConcurrency:maxConcurrency});
var testExecutedJobs = 0;
var testStartFired = false;
var testEndFired = false;
var testJobsStartFired = 0;
var testJobsEndFired = 0;
var testConcurrency = 0;
var myjob = function(args,next) {
setTimeout(function() {
testExecutedJobs++;
next();
},50);
}
// Let's add 10 job and add them to the queue
for (var i = 0; i<10; i++) {
q.add(myjob,['test'+i]);
}
q.on('start',function() {
testStartFired = true;
});
q.on('jobStart',function() {
var running = q.stats()._jobsRunning;
if (running>testConcurrency) testConcurrency = running;
testJobsStartFired++;
});
q.on('jobEnd',function() {
testJobsEndFired++;
});
q.on('end',function() {
testEndFired = true;
assert.equal(testExecutedJobs, 10);
assert.equal(testJobsStartFired,10);
assert.equal(testJobsEndFired,10);
assert.equal(testConcurrency,maxConcurrency);
assert.ok(testStartFired);
});
var running = q.stats()._jobsRunning;
assert.equal(testExecutedJobs,0);
assert.equal(testJobsStartFired,0);
assert.equal(testJobsEndFired,0);
assert.equal(running,0);
assert.ok(!testStartFired);
assert.ok(!testEndFired);
q.run();