https://github.com/blend/promise-utils
Lodash-like, dependency-free utilities for native ES6 promises.
https://github.com/blend/promise-utils
blend dependency-free javascript lodash nodejs promises typescript
Last synced: 6 months ago
JSON representation
Lodash-like, dependency-free utilities for native ES6 promises.
- Host: GitHub
- URL: https://github.com/blend/promise-utils
- Owner: blend
- License: mit
- Created: 2019-03-04T21:55:39.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-08-21T19:44:15.000Z (over 1 year ago)
- Last Synced: 2025-04-12T10:57:50.438Z (7 months ago)
- Topics: blend, dependency-free, javascript, lodash, nodejs, promises, typescript
- Language: TypeScript
- Homepage:
- Size: 594 KB
- Stars: 282
- Watchers: 7
- Forks: 15
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
promise-utils
=============
[](https://circleci.com/gh/blend/promise-utils)
[](https://coveralls.io/github/blend/promise-utils?branch=master)

Promise-utils is a dependency-free JavaScript/TypeScript library that
provides Lodash-like utility functions for dealing with native ES6
promises.
## Installation
```
$ npm install blend-promise-utils
```
## Usage Example
```js
const promiseUtils = require('blend-promise-utils')
const { promises: fs } = require('fs')
const request = require('request-promise-native');
const isEmpty = require('lodash.isempty');
const MS_IN_SECOND = 1000;
async function main() {
const cachedResponse = promiseUtils.memoize(
async (contents) => request(contents.url),
contents => contents.url,
15 * MS_IN_SECOND // contents could change
);
const fileContents = await promiseUtils.map(
['file1', 'file2', 'file3'],
async fileName => {
const rawData = await fs.readFile(fileName);
return JSON.parse(rawData);
},
);
while (true) {
await promiseUtils.delay(150); // avoid slamming CPU
await promiseUtils.mapSeries(
fileContents,
async contents => {
const remoteData = await cachedResponse(contents);
const { results, errors } = await promiseUtils.settleAll([
asyncFunction1(),
asyncFunction2(),
asyncFunction3(),
]);
if (!isEmpty(errors)) {
throw new Error(`Unable to settle all functions: ${JSON.stringify(errors)}`);
} else {
return results;
}
}
)
}
await promiseUtils.retry(flakyFunction, { maxAttempts: 3, delayMs: 150 })(flakyFunctionArgument);
await promiseUtils.timeout(longFunction, 60 * MS_IN_SECOND)(longFunctionArgument);
}
main()
```
## API
- [Documentation][2]
- [Past versions][3]
## Test
```
$ npm test
```
## Documentation
Build docs
```
$ make docs
```
Push docs to Github
```
$ make push-docs
```
## License
[MIT](LICENSE)
[1]: https://blend.github.io/promise-utils
[2]: https://blend.github.io/promise-utils/latest/
[3]: https://blend.github.io/promise-utils/versions.html