3.2.0 - 2024-03-25
- add
"sideEffects": false
topackage.json
#83
- updated types for the handler function in the promise pool processor
- bump dependencies
3.1.1 - 2024-01-31
- bump dependencies
- removed duplicated build files from
dist
(fixing #82)
3.1.0 - 2023-09-25
- clear timers from task timeouts to remove them from the event loop: this is helpful to clear up resources for long-running timeouts and fastly resolving tasks. If not cleared, the timeouts stay in the event loop until they’re due
- add keep error handler when calling
pool.handleError
afterpool.for
: previously the error handler was lost
- bump dependencies
3.0.0 - 2023-07-09
- Accept iterables and async iterables and not just arrays
- add performance testing script in
performance
directory: this is helpful to detect whether the promise pool is significantly slower thanPromise.all
- bump dependencies
- call
Error.captureStackTrace
only when available
- require Node.js v16
- require
ecmaScript
2021 - the
pool.items()
method changed from the narrower typeT[]
to the wider typeT[] | Iterable<T> | AsyncIterable<T>
which might be a breaking change for your code base
2.4.0 - 2023-02-10
- bump dependencies
- refined types when a promise or non-promise resuult will be handled
2.3.2 - 2022-08-05
- remove active task after handling the result or error #51
- we previously removed the active tasks before handling the result or error, which caused the pool to pick up the next task too early
2.3.1 - 2022-08-05
- bump dependencies
- stop processing items after throwing an error from inside the
pool.handleError()
method #51
2.3.0 - 2022-06-08
pool.useConcurrency(<num>)
: adjust the concurrency of a running pool
- bump dependencies
2.2.0 - 2022-05-20
pool.onTaskStarted((item, pool) => { … })
: configure a callback that runs when an item is about to be processedpool.onTaskFinished((item, pool) => { … })
: configure a callback that runs when an item finished processing
- bump dependencies
2.1.0 - 2021-12-14
- keep the original error in
error.raw
- this is useful if your errors store some kind of context
- the
PromisePoolError
instance would otherwise loose the original error context
class CustomError extends Error { … }
const { errors } = await PromisePool
.withConcurrency(2)
.for([1, 2, 3])
.process(() => {
throw new CustomError('Oh no')
})
errors[0].raw instanceof CustomError
// true
- bump dependencies
- run tests for Node.js v17
2.0.0 - 2021-11-09
The 2.x
release line changes the exports of this package:
// Now: 2.x
import { PromisePool } from '@supercharge/promise-pool'
// or
const { PromisePool } = require('@supercharge/promise-pool')
// Before: 1.x
import PromisePool from '@supercharge/promise-pool' // required the `esModuleInterop` flag in tsconfig.json
// or
const PromisePool = require('@supercharge/promise-pool')
The 1.x
releases used CommonJS- and ESM-compatible default exports. That required TypeScript packages using ESM imports to enable the esModuleInterop
flag in their tsconfig.json
file. The named exports in 2.x
don’t require that flag anymore.
1.9.0 - 2021-11-03
pool.stop()
method- add
downlevelIteration: true
option totsconfig.json
- bump dependencies
- use UVU and c8 for testing (instead of Jest)
- refined example output (in
examples/promise-pool.js
) - extend
README
with examples on how to stop an active promise pool
1.8.0 - 2021-09-24
- test code on Node.js v16
- provide
index
as the second argument in theprocess
functionawait PromisePool .withConcurrency(2) .for([1,2,3,4]) .process(async (num, index) => { // processing … })
- bump dependencies
- testing on Node.js v15
1.7.0 - 2021-04-11
- bump dependencies
- refactored code to not use the
@supercharge/goodies
package
- dependency to
@supercharge/goodies
1.6.2 - 2021-04-09
- bump dependencies
- missing concurrency in certain cases when not calling
.withConcurrency()
1.6.1 - 2021-03-28
- typing error when processing a promise pool that was created from non-static methods
1.6.0 - 2020-11-03
.handleError(handler)
method: aka “bring your own error handling”. This allows you to take over error handling from the pool. If you impelement the.handleError
method, the pool won’t collect errors anymore. It puts error handling in your hands.
- bump dependencies
- failed tasks are handled properly now and the pool ensures the concurrency limit. Before, the pool started to process all items as soon as one failed
1.5.0 - 2020-09-20
- bump dependencies
- return types for
results
anderrors
now resolve properly for sync and async action handlers
1.4.0 - 2020-09-17
- improved types supporting typed return values
- improved error handling when rejecting a promise without an error instance (thank you wzh)
- bump dependencies
- change
main
entrypoint inpackage.json
todist
folder - move test runner from
@hapi/lab
tojest
- move assertions from
@hapi/code
tojest
1.3.0 - 2020-07-16
- TypeScript typings
- bump dependencies
- moved code base to TypeScript to automatically generate type definitions
1.2.0 - 2019-10-15
- static methods for
.withConcurrency
and.for
- moves boilerplate from your code to the promise pool package
new Pool().for(items)
is nowPool.for(items)
)new Pool().withConcurrency(2)
is nowPool.withConcurrency(2)
)- it’s always the details :)
- bump dependencies
1.1.1 - 2019-09-24
- bump dependencies
- move package docs to Supercharge docs
1.1.0 - 2019-08-14
module.exports.default
- bump dependencies
- update NPM scripts
1.0.0
release 🚀 🎉