From 83fd971b6fab9013d6dc71401270f641f36317c7 Mon Sep 17 00:00:00 2001 From: Ludek Novy <13610612+ludeknovy@users.noreply.github.com> Date: Fri, 12 Apr 2024 17:58:08 +0200 Subject: [PATCH] Optimize memory usage in item data processing (#317) The commit replaces two 'const' declarations with 'let' in 'item-data-processing.ts' for rawData and rawDataArray. After these variables are used, they are set to null, freeing up memory space. The change is aimed at optimizing memory usage and improving performance. --- src/server/controllers/item/shared/item-data-processing.ts | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/src/server/controllers/item/shared/item-data-processing.ts b/src/server/controllers/item/shared/item-data-processing.ts index bbd192f..ccecccd 100644 --- a/src/server/controllers/item/shared/item-data-processing.ts +++ b/src/server/controllers/item/shared/item-data-processing.ts @@ -55,11 +55,13 @@ export const itemDataProcessing = async ({ projectName, scenarioName, itemId }) const responseFailures = await db.manyOrNone(responseMessageFailures(itemId)) const scenarioSettings = await db.one(getScenarioSettings(projectName, scenarioName)) - const rawData = await db.manyOrNone(findRawData(itemId)) - const rawDataArray = rawData?.map(row => [moment(row.timestamp).valueOf(), row.elapsed]) + let rawData = await db.manyOrNone(findRawData(itemId)) + let rawDataArray = rawData?.map(row => [moment(row.timestamp).valueOf(), row.elapsed]) const rawDataDownSampled = downsampleData(rawDataArray, MAX_SCATTER_CHART_POINTS) const groupedErrors = await db.manyOrNone(findGroupedErrors(itemId)) const top5ErrorsByLabel = await db.manyOrNone(findTop5ErrorsByLabel(itemId)) + rawData = null + rawDataArray = null if (aggOverview.number_of_sut_hostnames > 1) { sutMetrics = await db.many(sutOverviewQuery(itemId)) @@ -76,7 +78,6 @@ export const itemDataProcessing = async ({ projectName, scenarioName, itemId }) })) } - const { overview, overview: { duration },