Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/promise-queue/promise-queue
Promise-based queue
https://github.com/promise-queue/promise-queue
javascript promise promise-queue queue
Last synced: 3 months ago
JSON representation
Promise-based queue
- Host: GitHub
- URL: https://github.com/promise-queue/promise-queue
- Owner: promise-queue
- License: mit
- Created: 2013-12-16T11:37:05.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2022-09-15T17:14:18.000Z (over 2 years ago)
- Last Synced: 2024-05-17T08:42:23.080Z (8 months ago)
- Topics: javascript, promise, promise-queue, queue
- Language: JavaScript
- Size: 42 KB
- Stars: 231
- Watchers: 10
- Forks: 34
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# promise-queue [![NPM Version](https://badge.fury.io/js/promise-queue.png)](https://npmjs.org/package/promise-queue) [![Build Status](https://travis-ci.org/azproduction/promise-queue.png?branch=master)](https://travis-ci.org/azproduction/promise-queue) [![Coverage Status](https://coveralls.io/repos/azproduction/promise-queue/badge.png?branch=master)](https://coveralls.io/r/azproduction/promise-queue)
Promise-based queue
## Installation
`promise-queue` can be installed using `npm`:
```
npm install promise-queue
```## Interface
- `new Queue(Number maxConcurrent, Number maxQueued): Queue`
- `Queue#add(Function generator): Promise` - adds function argument that generates a promise to the queue
- `Queue#getQueueLength(): Number` - returns current length of buffer(added but not started promise generators) `it <= maxQueued`
- `Queue#getPendingLength(): Number` - returns number of pending(concurrently running) promises `it <= maxConcurrent`## Example
### Configure queue
By default `Queue` tries to use global Promises, but you can specify your own promises.
```js
Queue.configure(require('vow').Promise);
```Or use old-style promises approach:
```js
Queue.configure(function (handler) {
var dfd = $.Deferred();
try {
handler(dfd.resolve, dfd.reject, dfd.notify);
} catch (e) {
dfd.reject(e);
}
return dfd.promise();
});
```### Queue one by one example
```js
var maxConcurrent = 1;
var maxQueue = Infinity;
var queue = new Queue(maxConcurrent, maxQueue);app.get('/version/:user/:repo', function (req, res, next) {
queue.add(function () {
// Assume that this action is a way too expensive
// Call of this function will be delayed on second request
return downloadTarballFromGithub(req.params);
})
.then(parseJson('package.json'))
.then(function (package) {
res.send(package.version);
})
.catch(next);
});
```### Getting number of pending promises and queue(buffered promises) length
```js
var maxConcurrent = 1;
var maxQueue = 1;
var queue = new Queue(maxConcurrent, maxQueue);queue.add(function () {
queue.getQueueLength() === 0;
queue.getPendingLength() === 1;
return somePromise();
});queue.add(function () {
queue.getQueueLength() === 0;
queue.getPendingLength() === 0;
return somePromise();
});queue.getQueueLength() === 1;
queue.getPendingLength() === 1;
```[Live example](http://jsfiddle.net/RVuEU/1/)