Introducing Socket Firewall: Free, Proactive Protection for Your Software Supply Chain.Learn More
Socket
Book a DemoInstallSign in
Socket

@ssense/promise-pool

Package Overview
Dependencies
Maintainers
23
Versions
1
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@ssense/promise-pool

Allow to resolve a list of promises using a concurrency factor.

latest
Source
npmnpm
Version
1.0.0
Version published
Maintainers
23
Created
Source

@ssense/promise-pool

Promise Pool

class Pool

The idea behind a promise pool is that you want to handle a large volume of promises but you do not want to use Promise.all because it is an all or nothing approach. The promise pool allows you to execute a large number of promises concurrently and if any promise is to fail it will continue the execution of the promises uninterupted.
Also you can specify the number of promises that should be run in parallel to prevent overwhelming the function that is servicing your asynchronous requests. (see examples here)

Methods

MethodReturnsDescription
constructor(generator: PromiseGenerator, max: number)PromisePoolCreates a new instance of PromisePool
onResolved(callback: (data: any, index: number) => void)PromisePoolAdds a callback called every time a promise in the pool is resolved
onRejected(callback: (err: Error, index: number) => void)PromisePoolAdds a callback called every time a promise in the pool is rejected
run()Promise<PromisePoolStats>Starts the pool of promises, returning statistics about execution when finished

Details

constructor(generator: PromiseGenerator, max: number)

Creates a new instance of PromisePool

Parameters

NameTypeRequiredDescription
generatorPromiseGeneratorYesFunction that should return a promise on each call, or null if all promises are executed
maxnumberYesMaximum number of parallel promises to run

onResolved(callback: (data: any, index: number) => void)

Adds a callback called every time a promise in the pool is resolved

Parameters

NameTypeRequiredDescription
callbackFunctionYesFunction called every time a promise in the pool is resolved, receiving in parameter the promise return value, as well as the promise index in the pool

Return value

TypeDescription
PromisePoolThe current PromisePool instance

onRejected(callback: (err: Error, index: number) => void)

Adds a callback called every time a promise in the pool is rejected

Parameters

NameTypeRequiredDescription
callbackFunctionYesFunction called every time a promise in the pool is rejected, receiving in parameter the error, as well as the promise index in the pool

Return value

TypeDescription
PromisePoolThe current PromisePool instance

run()

Starts the pool of promises, returning statistics about execution when finished

Return value

TypeDescription
Promise<PromisePoolStats>Statistics about current pool execution

PromisePoolStats properties

NameTypeRequiredDescription
resolvednumberYesNumber of resolved promises after current pool run
rejectednumberYesNumber of rejected promises after current pool run
durationnumberYesCurrent pool run duration in milliseconds

Examples

import { Pool } from '@ssense/promise-pool';

// Create sample PromiseGenerator, throwing an error one time out of two
let i = 0;
const generator = (): any => {
    i += 1;
    if (i > 10) {
        // Return null after 10 runs, which will stop the promise pool
        return null;
    }

    return new Promise<number>((resolve, reject) => {
        const current = i;
        setTimeout(() => {
            return current % 2 === 0 ? resolve(current) : reject(new Error(current.toString()));
        }, 2);
    });
};

// Create a new promise pool, calling the above generator, and running 2 promises in parallel max
const pool = new Pool(generator, 2);

// Start the pool and wait for it to finish
const result = await pool.run();

// "result" contains the pool statistics with the current structure:
// {
//   resolved: 5,
//   rejected: 5,
//   duration: <total execution time in milliseconds>
// }

FAQs

Package last updated on 15 Nov 2021

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts