Skip to content
Execute Asynchronous Functions in Parallel - 2721

Execute Asynchronous Functions in Parallel – 2721

🔗LC2721 🟡 Medium 🧩 Pattern – Promises and Time

📅 Day 19/30 Days of JavaScript

Given an array of asynchronous functions functions, return a new promise promise. Each function in the array accepts no arguments and returns a promise. All the promises should be executed in parallel.

promise resolves:

  • When all the promises returned from functions were resolved successfully in parallel. The resolved value of promise should be an array of all the resolved values of promises in the same order as they were in the functions. The promise should resolve when all the asynchronous functions in the array have completed execution in parallel.

promise rejects:

  • When any of the promises returned from functions were rejected. promise should also reject with the reason of the first rejection.

Please solve it without using the built-in Promise.all function.

Example

Input: functions = [
  () => new Promise(resolve => setTimeout(() => resolve(5), 200))
]
Output: {"t": 200, "resolved": [5]}
Explanation: 
promiseAll(functions).then(console.log); // [5]

The single function was resolved at 200ms with a value of 5.

Example 2:

Input: functions = [
    () => new Promise(resolve => setTimeout(() => resolve(1), 200)), 
    () => new Promise((resolve, reject) => setTimeout(() => reject("Error"), 100))
]
Output: {"t": 100, "rejected": "Error"}
Explanation: Since one of the promises rejected, the returned promise also rejected with the same error at the same time.

Solution

TLDR – write a polyfill for Promise.all

/**
 * @param {Array<Function>} functions
 * @return {Promise<any>}
 */
var promiseAll = function (functions) {
    return new Promise((resolve, reject) => {
        // If functions is an empty array
        if (functions.length === 0) {
            resolve([]);
            return;
        }

        const results = [];
        let resolvedCount = 0;
        functions.forEach((fun, index) => {
            // We wait for each fn to resolve and store resolvedValue in the same order
            fun()
                .then((resolvedValue) => {
                    results[index] = resolvedValue;
                    resolvedCount++;
                    if (resolvedCount === functions.length) {
                        resolve(results);
                    }
                })
                // If any fn promise is rejected, then immediately reject the main promise
                .catch(reject);
        });
    });
};

/**
 * const promise = promiseAll([() => new Promise(res => res(42))])
 * promise.then(console.log); // [42]
 */
Back to Top