mirror of
https://github.com/element-hq/element-web
synced 2024-11-27 11:47:23 +03:00
Rewrite limitConcurrency to fix error catching
Make sure that we only catch errors that are a result of calling fn()
This commit is contained in:
parent
da1a5616eb
commit
71c1198d12
1 changed files with 22 additions and 22 deletions
|
@ -48,30 +48,30 @@ function checkBacklog() {
|
|||
|
||||
// Limit the maximum number of ongoing promises returned by fn to LIMIT and
|
||||
// use a FIFO queue to handle the backlog.
|
||||
function limitConcurrency(fn) {
|
||||
return new Promise((resolve, reject) => {
|
||||
const item = () => {
|
||||
ongoingRequestCount++;
|
||||
resolve();
|
||||
};
|
||||
async function limitConcurrency(fn) {
|
||||
if (ongoingRequestCount >= LIMIT) {
|
||||
// Enqueue this request for later execution
|
||||
backlogQueue.push(item);
|
||||
} else {
|
||||
item();
|
||||
}
|
||||
})
|
||||
.then(fn)
|
||||
.catch((err) => {
|
||||
ongoingRequestCount--;
|
||||
checkBacklog();
|
||||
throw err;
|
||||
})
|
||||
.then((result) => {
|
||||
ongoingRequestCount--;
|
||||
checkBacklog();
|
||||
return result;
|
||||
await new Promise((resolve, reject) => {
|
||||
backlogQueue.push(resolve);
|
||||
});
|
||||
}
|
||||
|
||||
let result;
|
||||
let error;
|
||||
|
||||
ongoingRequestCount++;
|
||||
try {
|
||||
result = await fn();
|
||||
} catch (err) {
|
||||
error = err;
|
||||
} finally {
|
||||
ongoingRequestCount--;
|
||||
checkBacklog();
|
||||
}
|
||||
|
||||
if (error) throw error;
|
||||
|
||||
return result;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in a new issue