Skip to content

Commit

Permalink
[minor] Use Infinity if concurrency value is falsy
Browse files Browse the repository at this point in the history
  • Loading branch information
lpinca committed Nov 30, 2019
1 parent 950e41a commit 6df06d9
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 16 deletions.
2 changes: 1 addition & 1 deletion lib/limiter.js
Expand Up @@ -19,7 +19,7 @@ class Limiter {
this.pending--;
this[kRun]();
};
this.concurrency = concurrency;
this.concurrency = concurrency || Infinity;
this.jobs = [];
this.pending = 0;
}
Expand Down
40 changes: 25 additions & 15 deletions test/limiter.test.js
Expand Up @@ -5,27 +5,37 @@ const assert = require('assert');
const Limiter = require('../lib/limiter');

describe('Limiter', () => {
it('limits the number of jobs allowed to run concurrently', (done) => {
const limiter = new Limiter(1);
describe('#ctor', () => {
it('takes a `concurrency` argument', () => {
const limiter = new Limiter(0);

limiter.add((callback) => {
setImmediate(() => {
callback();
assert.strictEqual(limiter.concurrency, Infinity);
});
});

describe('#kRun', () => {
it('limits the number of jobs allowed to run concurrently', (done) => {
const limiter = new Limiter(1);

limiter.add((callback) => {
setImmediate(() => {
callback();

assert.strictEqual(limiter.jobs.length, 0);
assert.strictEqual(limiter.pending, 1);
assert.strictEqual(limiter.jobs.length, 0);
assert.strictEqual(limiter.pending, 1);
});
});
});

limiter.add((callback) => {
setImmediate(() => {
callback();
limiter.add((callback) => {
setImmediate(() => {
callback();

assert.strictEqual(limiter.pending, 0);
done();
assert.strictEqual(limiter.pending, 0);
done();
});
});
});

assert.strictEqual(limiter.jobs.length, 1);
assert.strictEqual(limiter.jobs.length, 1);
});
});
});

0 comments on commit 6df06d9

Please sign in to comment.