HEX
Server: Apache/2.4.41 (Ubuntu)
System: Linux ip-172-31-42-149 5.15.0-1084-aws #91~20.04.1-Ubuntu SMP Fri May 2 07:00:04 UTC 2025 aarch64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/vhost/disk-apps/pwa.sports-crowd.com/node_modules/qjobs/tests/interval.js
#!/usr/bin/env node
var assert = require('assert');
var qjob = require('../qjobs');

// maximum number of jobs executed in parallels
var maxConcurrency = 5;

// delay between each group of maxConcurrency jobs done
var interval = 1000;

var q = new qjob({
    maxConcurrency:maxConcurrency,
    interval:interval
});

// number of total jobs
var maxJobs = 20;

// tests dedicated variables
var testExecutedJobs = 0;
var testNbSleep = 0;

// warning, if you change maxConcurrency, maxJobs
// or interval variable, you will have to review
// the testMaxNbSleep value
var testMaxNbSleep = 4;

var myjob = function(args,next) {
    setTimeout(function() {
        testExecutedJobs++;
        next();
    },args[1]);
}

// Let's add 10 job and add them to the queue
for (var i = 0; i<maxJobs; i++) {
    q.add(myjob,['test'+i,Math.random()*1000]);
}

q.on('end',function() {
    assert.equal(testExecutedJobs, maxJobs);
    assert.equal(testNbSleep, testMaxNbSleep);
    //console.log('Done');
});

q.on('jobStart',function(args) {
    //console.log(args[0]+' wait for '+args[1]+' ms');
});

q.on('sleep',function() {
    testNbSleep++;
    //console.log('zzZZzzzz for '+interval+'ms',testNbSleep);
});

q.on('continu',function() {
    //console.log('WAKE !');
});

q.run();