summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHubert Argasinski <argasinski.hubert@gmail.com>2017-06-06 23:15:49 -0400
committerHubert Argasinski <argasinski.hubert@gmail.com>2017-06-06 23:15:49 -0400
commit6df20fd2a1b9d7fc0e59410dd440bb9555c6bdf6 (patch)
treef3c2002e75da98b59b53091bb7424c386f424248
parentec9dab73153028e4abdd0216f55496b8bb6f4054 (diff)
downloadasync-concatLimit.tar.gz
add concatLimit [fixes #1426]concatLimit
-rw-r--r--lib/concatLimit.js22
-rw-r--r--lib/index.js3
-rw-r--r--mocha_test/concat.js37
3 files changed, 62 insertions, 0 deletions
diff --git a/lib/concatLimit.js b/lib/concatLimit.js
new file mode 100644
index 0000000..a86fd74
--- /dev/null
+++ b/lib/concatLimit.js
@@ -0,0 +1,22 @@
+import doParallelLimit from './internal/doParallelLimit';
+import concat from './internal/concat';
+
+/**
+ * The same as [`concat`]{@link module:Collections.concat} but runs a maximum of `limit` async operations at a time.
+ *
+ * @name concatLimit
+ * @static
+ * @memberOf module:Collections
+ * @method
+ * @see [async.concat]{@link module:Collections.concat}
+ * @category Collection
+ * @param {Array|Iterable|Object} coll - A collection to iterate over.
+ * @param {number} limit - The maximum number of async operations at a time.
+ * @param {AsyncFunction} iteratee - A function to apply to each item in `coll`,
+ * which should use an array as its result. Invoked with (item, callback).
+ * @param {Function} [callback(err)] - A callback which is called after all the
+ * `iteratee` functions have finished, or an error occurs. Results is an array
+ * containing the concatenated results of the `iteratee` function. Invoked with
+ * (err, results).
+ */
+export default doParallelLimit(concat);
diff --git a/lib/index.js b/lib/index.js
index 0e2e457..a9fbb17 100644
--- a/lib/index.js
+++ b/lib/index.js
@@ -72,6 +72,7 @@ import autoInject from './autoInject';
import cargo from './cargo';
import compose from './compose';
import concat from './concat';
+import concatLimit from './concatLimit';
import concatSeries from './concatSeries';
import constant from './constant';
import detect from './detect';
@@ -150,6 +151,7 @@ export default {
cargo: cargo,
compose: compose,
concat: concat,
+ concatLimit: concatLimit,
concatSeries: concatSeries,
constant: constant,
detect: detect,
@@ -246,6 +248,7 @@ export {
cargo as cargo,
compose as compose,
concat as concat,
+ concatLimit as concatLimit,
concatSeries as concatSeries,
constant as constant,
detect as detect,
diff --git a/mocha_test/concat.js b/mocha_test/concat.js
index 389b2de..97c0a96 100644
--- a/mocha_test/concat.js
+++ b/mocha_test/concat.js
@@ -54,4 +54,41 @@ describe('concat', function() {
done();
});
});
+
+ it('concatLimit basics', function(done) {
+ var running = 0;
+ var concurrency = {
+ 'foo': 2,
+ 'bar': 2,
+ 'baz': 1
+ };
+
+ async.concatLimit(['foo', 'bar', 'baz'], 2, function(val, next) {
+ running++;
+ async.setImmediate(function() {
+ expect(running).to.equal(concurrency[val]);
+ running--;
+ next(null, [val, val]);
+ });
+ }, function(err, result) {
+ expect(running).to.equal(0);
+ expect(err).to.eql(null);
+ expect(result).to.eql(['foo', 'foo', 'bar', 'bar', 'baz', 'baz']);
+ done();
+ });
+ });
+
+ it('concatLimit error', function(done) {
+ var arr = ['foo', 'bar', 'baz'];
+ async.concatLimit(arr, 2, function(val, next) {
+ if (val === 'bar') {
+ return next(new Error('fail'));
+ }
+ next(null, [val, val]);
+ }, function(err, result) {
+ expect(err).to.not.eql(null);
+ expect(result).to.eql(['foo', 'foo']);
+ done();
+ });
+ });
});