Skip to content

A robust Node.js/TypeScript package for managing concurrent async function calls. Employs a process pool for efficient task coordination, ensuring optimal system performance. Ideal for streamlining asynchronous workflows.

Notifications You must be signed in to change notification settings

Dubsado/nice-promise-pool

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

11 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

image

Usage

Add the dependency to your project:

yarn add nice-promise-pool

Example

Here's an example use case where we're grabbing 0-10 events per 1 second loop.

import { addEventToPool, onOpenSlot, getOpenSlotCount } from "nice-promise-pool";
import { queryEventDatabase } from "./utils/mockApi";

const INTERVAL_TIME = 1000;

// in the case where we loop back outside of the interval loop or for some reason
// the loop function takes longer than the interval time, we need to make sure
// the event loop doesn't bubble up on top of itself
let loopLock = false;

const onSuccessfulEvent = (payload: any, eventProcessed: EventToProcess) => {
  console.log(`successfully ran ${eventProcessed.id}`);
};

const onFailedEvent = (error: unknown, eventProcessed: EventToProcess) => {
  console.error(`failed to run ${eventProcessed.id}`);
  console.error(error);
};

/**
 * Runs the batch work. Will not allow itself to be called more than once at a time.
 * @returns
 */
async function loop() {
  if (loopLock) {
    console.log(`loop is already processing`);
    return;
  }
  loopLock = true;
  const openSlots: number = getOpenSlotCount();
  // this is going to return a number of promises per the available amount of slots
  const promises: Promise<any>[] = queryEventDatabase(openSlots);
  if (promises.length === 0) console.log(`nothing found in this loop`);
  for (const promise of promises) {
    const eventToProcess = addEventToPool(promise, {
      then: onSuccessfulEvent,
      catch: onFailedEvent,
    });
    console.log(`added ${eventToProcess.id} to be processed`);
  }
  loopLock = false;
}

// by calling loop first we don't have to wait one second upon boot
loop().then(() => {
  onOpenSlot(() => {
    loop();
  });
  setInterval(loop, INTERVAL_TIME);
});

Development

Clone this repo.

To install dependencies:

bun install

To run tests (continuously with Bun watch flag):

yarn test:w

This project was created using bun init in bun v0.5.2. Bun is a fast all-in-one JavaScript runtime.

About

A robust Node.js/TypeScript package for managing concurrent async function calls. Employs a process pool for efficient task coordination, ensuring optimal system performance. Ideal for streamlining asynchronous workflows.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published