From 95b645922329673eeab187f02fd2db658d0fff0e Mon Sep 17 00:00:00 2001 From: Angelika Serwa Date: Mon, 4 Nov 2024 13:14:54 +0100 Subject: [PATCH] [lib] Refactor threads queue in DMOpsQueueHandler Summary: https://linear.app/comm/issue/ENG-9808/consider-modifying-the-queues-logic-to-be-more-resilient Depends on D13860 Test Plan: Add entities to the threads queue by calling processDMOps from useProcessDMOperation and verify entities are processed. Reviewers: tomek, kamil Reviewed By: tomek Subscribers: ashoat Differential Revision: https://phab.comm.dev/D13861 --- .../dm-ops/dm-ops-queue-handler.react.js | 19 ++++++++++++++----- 1 file changed, 14 insertions(+), 5 deletions(-) diff --git a/lib/shared/dm-ops/dm-ops-queue-handler.react.js b/lib/shared/dm-ops/dm-ops-queue-handler.react.js index ddf8648e0a..b8a7b4f609 100644 --- a/lib/shared/dm-ops/dm-ops-queue-handler.react.js +++ b/lib/shared/dm-ops/dm-ops-queue-handler.react.js @@ -63,7 +63,6 @@ function DMOpsQueueHandler(): React.Node { }, [prune]); const threadInfos = useSelector(threadInfoSelector); - const prevThreadInfosRef = React.useRef({}); const queuedThreadOperations = useSelector( state => state.queuedDMOperations.threadQueue, @@ -95,14 +94,20 @@ function DMOpsQueueHandler(): React.Node { const { enqueue } = useActionsQueue(processItem); - React.useEffect(() => { - const prevThreadInfos = prevThreadInfosRef.current; - prevThreadInfosRef.current = threadInfos; + const runningThreadOperations = React.useRef>(new Set()); + React.useEffect(() => { for (const threadID in queuedThreadOperations) { - if (!threadInfos[threadID] || prevThreadInfos[threadID]) { + if (!threadInfos[threadID]) { + continue; + } + + if (runningThreadOperations.current.has(threadID)) { continue; } + + runningThreadOperations.current.add(threadID); + enqueue([ ...queuedThreadOperations[threadID].map(item => ({ type: 'operation', @@ -117,6 +122,10 @@ function DMOpsQueueHandler(): React.Node { }, }, }, + { + type: 'function', + itemFunction: () => runningThreadOperations.current.delete(threadID), + }, ]); } }, [dispatch, enqueue, queuedThreadOperations, threadInfos]);