Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

pjobs

Package Overview
Dependencies
Maintainers
1
Versions
16
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

pjobs

A simple and efficient queue job executor using promises. And some promise's utilities.

  • 1.0.6
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
132
decreased by-8.33%
Maintainers
1
Weekly downloads
 
Created
Source

Node.js CI Coverage Status

pjobs

A simple and efficient queue job executor using promises. And some promise's utilities.

install

npm install --save pjobs

usage

queuePromises

defines an executor for jobs. A job is just a function that returns a Promise. You can also control concurrency and promises.

import { queuePromises } from 'pjobs'
const queue = queuePromises({ 
  concurrency: 1, // maximum of promises running concurrently
  onProgress (status) { // allow you to inform users about execution progress
    console.log('done: ', status.percent, '%')
    console.log('speed: ', status.rate) // jobs runned per second
    console.log('estimated time remaining to finish: ', status.timeRemaining)
  }
})
queue.enqueue(async () => { // add a job to the queue
  console.log('task 1')
})
queue.enqueue(async () => { // add another job to the queue
  console.log('task 2')
})

await queue.waitFor() // wait for all jobs to be finished.

defer

allow you to defer promise's resolving or rejecting.

import { queuePromises, defer } from 'pjobs'
const taskOne = defer<void>() // defines the deferred promise
const queue = queuePromises()
queue.enqueue(async () => {
  console.log('task 1')
  taskOne.resolve() // resolves the deferred promise
})
queue.enqueue(async () => {
  console.log('task 2')
})
expect(queue.state()).not.toBe('idle')
await taskOne.promise // wait for the deferred promise to be resolved
await queue.waitFor()

sleep

allow you pause execution flow for some miliseconds

import { sleep } from 'pjobs'
await sleep(100) // pause execution flow for 100 miliseconds

asap

delay execution of a function to as soon as possible

import { asap } from 'pjobs'
asap(()=>console.log('b')) // 'b' will be logged after 'a'
console.log('a')

FAQs

Package last updated on 28 Oct 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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc