X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=benchmarks%2Fversus-external-pools%2Ffunctions%2Ffunction-to-bench.js;h=ff13bc9ecd2ad04fb034bab8a622198ad748e10a;hb=9d698f93d3cb8c2567f9a92aa29ab35d035725b4;hp=565f811219cbccea2cdb1991b1c8a9a337fa9618;hpb=6e9d10db05ac2bbc85373195a5c885d2492fee61;p=poolifier.git diff --git a/benchmarks/versus-external-pools/functions/function-to-bench.js b/benchmarks/versus-external-pools/functions/function-to-bench.js index 565f8112..ff13bc9e 100644 --- a/benchmarks/versus-external-pools/functions/function-to-bench.js +++ b/benchmarks/versus-external-pools/functions/function-to-bench.js @@ -1,14 +1,52 @@ -module.exports = function (data) { - if (data.taskType === 'CPU_INTENSIVE') { - // CPU intensive task - for (let i = 0; i < 5000; i++) { - const o = { - a: i +'use strict' +/** + * The task function to execute during pools benchmarks. + * NOTE: This function requires to be self-contained, thread-safe and re-entrant (node-worker-threads-pool requirement). + * @param {*} data The worker data. + * @returns {*} The result. + */ +const functionToBench = data => { + const crypto = require('node:crypto') + const fs = require('node:fs') + const TaskTypes = { + CPU_INTENSIVE: 'CPU_INTENSIVE', + IO_INTENSIVE: 'IO_INTENSIVE' + } + data = data || {} + data.taskType = data.taskType || TaskTypes.CPU_INTENSIVE + data.taskSize = data.taskSize || 5000 + const baseDirectory = `/tmp/poolifier-benchmarks/${crypto.randomInt( + 281474976710655 + )}` + switch (data.taskType) { + case TaskTypes.CPU_INTENSIVE: + // CPU intensive task + for (let i = 0; i < data.taskSize; i++) { + const o = { + a: i + } + JSON.stringify(o) + } + return { ok: 1 } + case TaskTypes.IO_INTENSIVE: + // IO intensive task + if (fs.existsSync(baseDirectory) === true) { + fs.rmSync(baseDirectory, { recursive: true }) + } + fs.mkdirSync(baseDirectory, { recursive: true }) + for (let i = 0; i < data.taskSize; i++) { + const filePath = `${baseDirectory}/${i}` + fs.writeFileSync(filePath, i.toString(), { + encoding: 'utf8', + flag: 'a' + }) + fs.readFileSync(filePath, 'utf8') } - JSON.stringify(o) - } - return { ok: 1 } - } else { - throw new Error('Please specify the task type') + fs.rmSync(baseDirectory, { recursive: true }) + return { ok: 1 } + default: + throw new Error(`Unknown task type: ${data.taskType}`) } } + +module.exports = functionToBench