Add pipeAsyncFunctions
This commit is contained in:
22
snippets/pipeAsyncFunctions.md
Normal file
22
snippets/pipeAsyncFunctions.md
Normal file
@ -0,0 +1,22 @@
|
||||
### pipeAsyncFunctions
|
||||
|
||||
Performs left-to-right function composition.
|
||||
|
||||
Use `Array.reduce()` with the spread operator (`...`) to perform left-to-right function composition using `Promise.then()`. The functions can return a combination of: simple values, `Promise`'s, or they can be defined as `async` ones returning through `await`.
|
||||
All functions must be unary.
|
||||
|
||||
```js
|
||||
const pipeAsyncFunctions = (...fns) => arg => fns.reduce((p, f) => p.then(f), Promise.resolve(arg));
|
||||
```
|
||||
|
||||
```js
|
||||
const sum = pipeAsyncFunctions(
|
||||
x => x + 1,
|
||||
x => new Promise(resolve => setTimeout(() => resolve(x + 2), 1000)),
|
||||
x => x + 3,
|
||||
async x => (await x) + 4
|
||||
);
|
||||
(async () => {
|
||||
console.log(await sum(5)); // 15 (after one second)
|
||||
})();
|
||||
```
|
||||
@ -169,6 +169,7 @@ partition:array,object,function
|
||||
percentile:math
|
||||
pick:object,array
|
||||
pickBy:object,array,function
|
||||
pipeAsyncFunctions:adapter,function,async
|
||||
pipeFunctions:adapter,function
|
||||
pluralize:string
|
||||
powerset:math
|
||||
|
||||
2
test/pipeAsyncFunctions/pipeAsyncFunctions.js
Normal file
2
test/pipeAsyncFunctions/pipeAsyncFunctions.js
Normal file
@ -0,0 +1,2 @@
|
||||
const pipeAsyncFunctions = (...fns) => arg => fns.reduce((p, f) => p.then(f), Promise.resolve(arg));
|
||||
module.exports = pipeAsyncFunctions
|
||||
24
test/pipeAsyncFunctions/pipeAsyncFunctions.test.js
Normal file
24
test/pipeAsyncFunctions/pipeAsyncFunctions.test.js
Normal file
@ -0,0 +1,24 @@
|
||||
const test = require('tape');
|
||||
const pipeAsyncFunctions = require('./pipeAsyncFunctions.js');
|
||||
|
||||
test('Testing pipeAsyncFunctions', async (t) => {
|
||||
//For more information on all the methods supported by tape
|
||||
//Please go to https://github.com/substack/tape
|
||||
t.true(typeof pipeAsyncFunctions === 'function', 'pipeAsyncFunctions is a Function');
|
||||
//t.deepEqual(pipeAsyncFunctions(args..), 'Expected');
|
||||
//t.equal(pipeAsyncFunctions(args..), 'Expected');
|
||||
//t.false(pipeAsyncFunctions(args..), 'Expected');
|
||||
//t.throws(pipeAsyncFunctions(args..), 'Expected');
|
||||
t.equal(
|
||||
await pipeAsyncFunctions(
|
||||
(x) => x + 1,
|
||||
(x) => new Promise((resolve) => setTimeout(() => resolve(x + 2), 0)),
|
||||
(x) => x + 3,
|
||||
async (x) => await x + 4,
|
||||
)
|
||||
(5),
|
||||
15,
|
||||
'pipeAsyncFunctions result should be 15'
|
||||
);
|
||||
t.end();
|
||||
});
|
||||
Reference in New Issue
Block a user