Cancel pending promises with ease!
npm i oathbreaker
Create an Oath
and break it:
const Oath = require('oathbreaker')
const oath = Oath((resolve, reject) => {
const t = setTimeout(() => resolve('ok'), 5e3)
return () => clearTimeout(t)
})
setTimeout(() => oath.break(), 3e3)
The executor function return value should be falsy or a function. If a function's returned, it's called if/when the oath is broken.
The executor function takes an optional 3rd argument. This is an AbortSignal
, which can be passed to other methods (e.g. https.request()
) or checked in business logic to see whether the oath was broken:
const https = require('https')
const Oath = require('oathbreaker')
const oath1 = Oath((resolve, reject, signal) => {
https.get('<url>', { signal }, res => {
// handle response
}).once('error', reject)
})
const oath2 = Oath((resolve, reject, signal) => {
// do some stuff
if (signal.aborted) return
// do some other stuff
})
Similar to Promise.all()
except it breaks other oaths (i.e. cancels pending promises) when 1 rejects:
Oath.all([oath1, oath2, ... ])
.then(() => {
// all promises resolved
})
.catch(() => {
// 1 promise rejected,
// others pending are canceled
})
Similar to Promise.any()
except it breaks other oaths when 1 resolves:
Oath.any([oath1, oath2, ... ])
.then(() => {
// 1 promise resolved,
// others pending are canceled
})
.catch(() => {
// All promises rejected
})
Similar to Promise.race()
except it breaks other oaths when 1 resolves or rejects:
Oath.race([oath1, oath2, ... ])
.then(() => {
// 1 promise resolved,
// others pending are canceled
})
.catch(() => {
// 1 promise rejected,
// others pending are canceled
})
npm test
npm run lint
or npm run lint:fix
Licensed under MIT.