Discover how to handle many tasks at once without messy code or missed results!
Why Promise.race and Promise.allSettled in Node.js? - Purpose & Use Cases
Start learning this pattern below
Jump into concepts and practice - no test required
Imagine you have several tasks running at the same time, like downloading files or fetching data from different websites, and you want to know when the first one finishes or when all of them have completed, no matter if they succeed or fail.
Manually tracking each task's completion is tricky and messy. You have to write lots of code to check each task's status, handle errors separately, and decide when to move on. This can easily lead to bugs and slow down your program.
Promise.race and Promise.allSettled let you handle multiple tasks easily. Promise.race gives you the result of the first task that finishes, while Promise.allSettled waits for all tasks to finish and tells you their outcomes, whether success or failure.
let finished = false;
tasks.forEach(task => {
task.then(result => {
if (!finished) {
finished = true;
console.log('First done:', result);
}
}).catch(() => {});
});Promise.race(tasks).then(result => console.log('First done:', result));You can easily manage many asynchronous tasks and react quickly to the first result or wait for all results without complicated code.
When loading images on a webpage, you might want to show the first image that loads quickly (Promise.race) or wait until all images have either loaded or failed before showing a gallery (Promise.allSettled).
Manually tracking multiple async tasks is complex and error-prone.
Promise.race returns the first finished task's result automatically.
Promise.allSettled waits for all tasks and reports their success or failure.
Practice
Promise.race do when given multiple promises?Solution
Step 1: Understand Promise.race behavior
Promise.race returns as soon as any promise settles (resolves or rejects).Step 2: Compare with other Promise methods
Unlike Promise.all or allSettled, it does not wait for all promises.Final Answer:
Returns the result or error of the first promise that finishes. -> Option DQuick Check:
Promise.race = first finished promise result [OK]
- Thinking it waits for all promises
- Assuming it only returns successful results
- Believing it cancels other promises
Promise.allSettled with an array of promises named tasks?Solution
Step 1: Recall Promise.allSettled usage
Promise.allSettled returns a promise that resolves with an array of results.Step 2: Check correct method chaining
We use .then() to handle the resolved results, not .catch() or .resolve().Final Answer:
Promise.allSettled(tasks).then(results => console.log(results)); -> Option CQuick Check:
Use .then() to get allSettled results [OK]
- Using .catch() instead of .then() for results
- Trying to use .resolve() method on promise
- Assuming .finally() receives results
const p1 = new Promise(res => setTimeout(() => res('A'), 100));
const p2 = new Promise((_, rej) => setTimeout(() => rej('Error'), 50));
Promise.race([p1, p2])
.then(console.log)
.catch(console.error);What will be printed?
Solution
Step 1: Identify which promise settles first
p2 rejects after 50ms, p1 resolves after 100ms, so p2 finishes first.Step 2: Understand Promise.race behavior on rejection
Promise.race rejects immediately with the first rejection, so .catch logs 'Error'.Final Answer:
'Error' -> Option AQuick Check:
First finished promise is rejection 'Error' [OK]
- Assuming resolve wins over reject
- Expecting an array instead of single result
- Thinking code throws syntax error
const promises = [Promise.resolve(1), Promise.reject('fail')];
Promise.allSettled(promises).catch(console.error);Solution
Step 1: Recall Promise.allSettled behavior
It waits for all promises and never rejects, it always resolves with results.Step 2: Understand .catch usage here
Since it never rejects, .catch will never be called, so error handling is ineffective.Final Answer:
Promise.allSettled never rejects, so .catch will never run. -> Option BQuick Check:
allSettled always resolves, .catch unused [OK]
- Thinking allSettled rejects on any promise failure
- Believing async/await is required
- Assuming .then() must come before .catch() always
task1, task2, and task3. You want to get the first task that finishes successfully, but if all fail, you want to know all errors. Which approach correctly achieves this?Solution
Step 1: Understand requirement for first success or all errors
Promise.race gives first finished promise, but may reject if first is failure.Step 2: Combine Promise.race and Promise.allSettled
If Promise.race rejects, then run Promise.allSettled to collect all errors from all tasks.Step 3: Evaluate other options
Promise.allSettled alone waits for all, no early success; Promise.all fails fast; ignoring errors loses info.Final Answer:
Use Promise.race on all tasks, then if it rejects, run Promise.allSettled to get all errors. -> Option AQuick Check:
race first success, allSettled for all errors [OK]
- Using allSettled only and waiting too long
- Ignoring rejected promises in race
- Using all which fails on first rejection
